标题:扑克牌排序问题
只看楼主
yqiong
Rank: 1
等 级:新手上路
帖 子:315
专家分:0
注 册:2007-7-4
结帖率:83.33%
 问题点数:0 回复次数:13 
扑克牌排序问题
试题一:
有6副带不同底色的扑克牌, 其底色分别为红、绿、蓝、白、粉、紫6种颜色. 现要求编写程序对这6副牌进行排序, 排序规则及做题要求如下:

排序规则:
排序优先度为:
1. 属性优先度:  点数 > 底色 > 花色 (即: 在排序时, “点数”要比“颜色”和“花色”重要, 而“颜色”又比“花色”重要);
2. 点数优先度:  3 > 4 > 5 > 6 > 7 > 8 > 9 > 10 > J > Q > K > A > 2 > 小王 > 大王
3. 底色优先度:  红 > 绿 > 蓝 > 白 > 粉 > 紫
4. 花色优先度:  红心 > 黑桃 > 方块 > 梅花

要求:
1. 编写合理的数据结构表示每张牌, 并说明数据结构中每个域的含意; (5分)
2. 编写用来产生供排序使用的初始排列的6副牌(可以是任意顺序)的函数, 并对关键性语句进行必要的注释; (25分)
3. 编写对6副牌进行排序的函数, 并在适当位置进行注释, 以增强程序的可读性. (60分)
4. 编写主函数, 调用上述函数对6副牌进行排序. (5分)
5. 将排序前和排序后的扑克牌的排序情况, 分别输出到源程序所在目录(或称文件夹)中的两个文本文件中 (排序前的牌放在“Before.txt”中, 排序后的牌放在“After.txt”中); (5分)
搜索更多相关主题的帖子: 扑克牌 梅花 底色 花色 点数 
2008-03-29 19:12
yqiong
Rank: 1
等 级:新手上路
帖 子:315
专家分:0
注 册:2007-7-4
得分:0 
第一,二问我写成下面这样,编译通不过,请问错哪了呀?要怎么改?
#include <iostream.h>
#include <fstream.h>
#include <stdlib.h>
#include <stdio.h>
#include <math.h>
enum dotnum{three,four,five,six,seven,eight,nine,ten,J,Q,K,A,two,sking,bking};
enum dise{red,green,blue,white,pink,purple};
enum huase{hongxi,heitiao,fangkuai,meihua};
void creatno();

struct card
{
enum dotnum a;
enum dise b;
enum huase c;
} cards[330];


void creatno()
{
    int i;
    for(i=0;i<324;i++)
    { cards[i].a=(enum dotnum)(rand()%13+1);
      cards[i].b=(enum dise)(rand()%6+1);
      cards[i].c=(enum huase)(rand()%5+1);
    }
    ofstream outfile("before.txt");
    if(!outfile)
    {cerr<<"can't open file."<<endl;
    exit(1);
    }
    for(i=0;i<324;i++)
    {
        outfile<<cards[i].a<<"    ";
        outfile<<cards[i].b<<"    ";
        outfile<<cards[i].c<<"    ";
        outfile<<endl<<endl;
    }
}

void main()
{
    creatno();
}
2008-03-29 19:13
sunkaidong
Rank: 4
来 自:南京师范大学
等 级:贵宾
威 望:12
帖 子:4496
专家分:141
注 册:2006-12-28
得分:0 
你的符号有问题....都换成英语的逗号
冒昧问一下..这个题目最后不就是全部相同的数字在一起了吗?在一起的数字按花色排好了

[[it] 本帖最后由 sunkaidong 于 2008-3-29 19:26 编辑 [/it]]

学习需要安静。。海盗要重新来过。。
2008-03-29 19:20
aipb2007
Rank: 8Rank: 8
来 自:CQU
等 级:贵宾
威 望:40
帖 子:2879
专家分:7
注 册:2007-3-18
得分:0 
没看清楚题意,到底是从before.txt的文件读数据,还是自己用6副牌洗牌?

Fight  to win  or  die...
2008-03-29 20:02
yqiong
Rank: 1
等 级:新手上路
帖 子:315
专家分:0
注 册:2007-7-4
得分:0 
#include <iostream.h>
#include <fstream.h>
#include <stdlib.h>
#include <stdio.h>
#include <math.h>
void sort(struct card cards[]);
enum dotnum{three,four,five,six,seven,eight,nine,ten,J,Q,K,A,two,sking,bking};
enum dise{red,green,blue,white,pink,purple};
enum huase{hongxi,heitiao,fangkuai,meihua};
void creatno();

struct card
{
enum dotnum a;//代表点数
enum dise b;//代表底色
enum huase c;//代表花色
} cards[324],showcard;


void creatno()
{
    int i;
    for(i=0;i<324;i++)
    { cards[i].a=(enum dotnum)(rand()%15);
      cards[i].b=(enum dise)(rand()%6);
      cards[i].c=(enum huase)(rand()%4);
    }
    ofstream outfile1("before.txt");
    if(!outfile1)
    {cerr<<"can't open file."<<endl;
    exit(1);
    }
    outfile1<<"dotnum"<<"     ";
    outfile1<<"dise"<<"     ";
    outfile1<<"huase"<<"     "<<endl;

    for(i=0;i<324;i++)
{

        outfile1<<cards[i].a<<"         ";
        outfile1<<cards[i].b<<"         ";
        outfile1<<cards[i].c<<"         ";
        outfile1<<endl<<endl;
}
}


void sort(struct card cards[])
{
    int i,j;
    for(i=0;i<323;i++)
        for(j=0;j<324;j++)
            if(cards[i].a>cards[i+1].a)
            {showcard=cards[i];cards[i]=cards[i+1];cards[i+1]=showcard;}
            else {if(cards[i].b>cards[i+1].b)
                        { showcard=cards[i];cards[i]=cards[i+1];cards[i+1]=showcard;}
                  else if(cards[i].c>cards[i+1].c)
                  {showcard=cards[i];cards[i]=cards[i+1];cards[i+1]=showcard;}
            }
}

void arrayout(struct card cards[])
{
        ofstream outfile2("after.txt");
    if(!outfile2)
    {
        cerr<<"can't open file."<<endl;
        exit(1);
    }
        outfile2<<"dotnum"<<"     ";
    outfile2<<"dise"<<"     ";
    outfile2<<"huase"<<"     "<<endl;

    for(int i=0;i<324;i++)
    {    outfile2<<cards[i].a<<"         ";
        outfile2<<cards[i].b<<"         ";
        outfile2<<cards[i].c<<"         ";
        outfile2<<endl<<endl;
    }
}

void main()
{
    creatno();
    sort(cards);
    arrayout(cards);

}
2008-03-29 20:23
yqiong
Rank: 1
等 级:新手上路
帖 子:315
专家分:0
注 册:2007-7-4
得分:0 
自已,洗好放在before,排序好后放在after
 我上面写的好像排序有问题,提议一下吧!
谢谢了!
2008-03-29 20:25
yqiong
Rank: 1
等 级:新手上路
帖 子:315
专家分:0
注 册:2007-7-4
得分:0 
这排序到底应该怎么写呢???下面这样排序后没一点规则呢-:(
    for(i=0;i<323;i++)
        for(j=0;j<324;j++)
        {    
            if(cards[i].c>cards[i+1].c)
                 {showcard=cards[i];cards[i]=cards[i+1];cards[i+1]=showcard;}
        
            if(cards[i].b>cards[i+1].b)
                { showcard=cards[i];cards[i]=cards[i+1];cards[i+1]=showcard;}
            
            if(cards[i].a>cards[i+1].a)
              {showcard=cards[i];cards[i]=cards[i+1];cards[i+1]=showcard;}
             
        }
}
2008-03-29 20:32
yqiong
Rank: 1
等 级:新手上路
帖 子:315
专家分:0
注 册:2007-7-4
得分:0 
[bo]以下是引用 [un]sunkaidong[/un] 在 2008-3-29 19:20 的发言:[/bo]

你的符号有问题....都换成英语的逗号
冒昧问一下..这个题目最后不就是全部相同的数字在一起了吗?在一起的数字按花色排好了

应该是这样的吧!

排序怎么实现,能否帮忙编一下,^_^
2008-03-29 20:35
aipb2007
Rank: 8Rank: 8
来 自:CQU
等 级:贵宾
威 望:40
帖 子:2879
专家分:7
注 册:2007-3-18
得分:0 
for(i=0;i<324;i++)
    { cards[i].a=(enum dotnum)(rand()%13+1);
      cards[i].b=(enum dise)(rand()%6+1);
      cards[i].c=(enum huase)(rand()%5+1);
    }
这段代码不能保证得到6副牌,只能保证324张牌

你的设计显然不好,你应该单独用个函数比较两个结构体大小,再将它作为参数给 sort调用,或者直接在sort内部调用。

Fight  to win  or  die...
2008-03-29 21:17
aipb2007
Rank: 8Rank: 8
来 自:CQU
等 级:贵宾
威 望:40
帖 子:2879
专家分:7
注 册:2007-3-18
得分:0 
还有,不应该选择数组实现(排序中太多拷贝和临时变量),链表比较合适。

Fight  to win  or  die...
2008-03-29 21:20



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-206050-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.427856 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved