- 1、本文档共13页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
毕业,课程,设计,数据结构,算法,火车毕业,课程,设计,数据结构,算法,火车
1游戏规则
将一副扑克牌平均分成两份,每人拿一份。玩家先拿出手中的第一张扑克牌放在桌上,然后电脑也拿出手中的第一张扑克牌,并放在玩家刚打出的扑克牌的下面,就像这样两人交替出牌。出牌时,如果某人打出的牌与桌上某张牌的牌面相同,即可将两张相同的牌及其中间所夹的牌全部取走,并依次放到自己手中牌的末尾。当任意一人手中的牌全部出完时,游戏结束,对手获胜。?
2.程序功能
1)能自动生成两副牌,一副属于电脑,一副属于玩家;
2)电脑能够自动出牌;
3)能正确显示电脑和玩家双方的牌数;
4)电脑能够收牌时,自动收牌;
5)玩家能够收牌时,输入对应的牌序号,判定正确后收牌。
3.主要功能的实现
#includestdlib.h
#includestdio.h
#includetime.h
#includewindows.h
struct Card
{ int suit; /*定义花色,黑桃、红桃、梅花、方片分别为1、2、3、4,为0表示是王*/
int number; /*定义点数,范围是1~13,如果是王则14,15分别表示大小王*/
};
struct Poker /*定义玩家手中的牌和赢取的牌*/
{ Card pile[54];
int top;
};
struct Sentcard
{ int suit;
int number;
int poc; /*这个是定义哪一方放的牌,1表示plyer,2表示computer*/
};
struct SentPoker /*定义已经放好的牌*/
{ Sentcard pile[15]; /*最多是15个,因为1~13再加上王,再来一张必定是重复的牌*/
int top;
};
void Shuffle(int *data) /*洗牌的函数*/
{ int n;
int i=0,j=0;
int test=0;
srand((int)time(NULL));
while(i54)
{ n=rand()%54+1;
if(i==0)
data[i++]=n;
else
{ for(j=0;ji;j++)
if(data[j]==n)
{ test=1; /*说明有当前产生的随机数是重复的*/
break;
}
if(test==0) /*如果不是重复的*/
{ data[i]=n;
i++;
}
test=0;
}
}
}
/*发牌的函数,发牌规则:53、54为大小王,其余以黑桃,红桃,梅花,方片的顺序点入*/
void Deal(int *data,Poker *player,Poker *computer)
{ for(int i=0;i54;i++)
{ if(i%2)
{ player-top++;
switch(data[i]) /*先为玩家发牌*/
{ case 53: {computer-pile[player-top].suit=0; computer-pile[player-top].number=14;} break;
case 54: {computer-pile[player-top].suit=0; computer-pile[player-top].number=15;} break;
default: {computer-pile[player-top].suit=(data[i]-1)/13+1; computer-pile[player-top].number=(data[i]-1)%13+1;} break;
}
}
else
{ computer-top++;
switch(data[i])
{ case 53: {player-pile[computer-top].suit=0; player-pile[computer-top].number=14;} break;
case 54: {player-pile[computer-top].suit=0; player-pile[computer-top].number=15;} break;
default: {player-pile[computer-top].suit=(data[i]-1)/13+1; player-pile[computer-top].numb
您可能关注的文档
最近下载
- 民用无人机驾驶员训练手册(2020).docx VIP
- 人教PEP版(2024)三年级下册英语Unit 6 Numbers in life单元整体教学设计(共6课时).docx
- 肺部结节影的影像学诊断与鉴别诊断.ppt
- 国网电动汽车服务有限公司招聘笔试题库2022.pdf
- 自娱自乐攻略适用21.0211新春版 by龙行天下Iray.xlsx VIP
- 基于单片机的智能衣柜控制系统设计.docx
- 搅拌站沙石供应合同模板.docx VIP
- 基于单片机的智能家居语音识别控制系统.docx
- 2022道德与法治课程标准解读与学习心得:教学评价的新趋势.pdf VIP
- 2025年九州职业技术学院单招职业技能测试题库及答案(典优).docx
文档评论(0)