- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
毕业,课程,设计,数据结构,算法,火车毕业,课程,设计,数据结构,算法,火车
目录
设计目的
总体设计
功能实现
测试结果
5 心得体会
设计目的:
培养运用算法与数据结构的基本知识解决实际编程中的数据结构设计和算法设计问题。
培养独立设计程序与解决问题的能力,培养学生团队协作集成程序模块及调试能力。
培养初步的软件设计及软件测试的能力。
总体设计:
#include stdio.h
struct queue
{
int data[1000];
int head;
int tail;
};
struct stack
{
int data[10];
int top;
};
int main()
{
printf( ******************拉火车*******************\n);
printf(游戏的规则是这样的:player和player2将一副扑克牌平均分成两份,每人拿一份。player先拿出手中的\n);
printf(第一张扑克牌放在桌上,然后player2也拿出手中的第一张扑克牌,并放在player刚打出的扑克牌\n);
printf(的上面,就像这样两人交替出牌。出牌时,如果某人打出的牌与桌上某张牌的牌面相同,即\n);
printf(可将两张相同的牌及其中间所夹的牌全部取走,并依次放到自己手中牌的末尾。当任意一人\n);
printf(手中的牌全部出完时,游戏结束,对手获胜。\n);
printf( ******************拉火车*******************\n);
struct queue q1, q2;
struct stack s;
int book[10];
int i, t;
//初始化队列
q1.head = 1; q1.tail = 1;
q2.head = 1; q2.tail = 1;
//初始化栈
s.top = 0;
//初始化用来标记的数组,用来标记哪些牌已经在桌上
for (i = 1; i = 1000; i++)
book[i] = 0;
//依次向队列插入6个数
//player手上的6张牌
printf(player的6张手牌);
for (i = 1; i = 6; i++)
{
scanf_s(%d, q1.data[q1.tail]);
q1.tail++;
}
//player2手上的6张牌
printf(player2的6张手牌);
for (i = 1; i = 6; i++)
{
scanf_s(%d, q2.data[q2.tail]);
q2.tail++;
}
while (q1.headq1.tail q2.headq2.tail) //当队列不为空的时候执行循环
{
t = q1.data[q1.head];//player出一张牌
//判断player当前打出的牌是否能赢牌
if (book[t] == 0) //表明桌上没有牌面为t的牌
{
//player此轮没有赢牌
q1.head++; //player已经打出一张牌,所以要把打出的牌出队
s.top++;
s.data[s.top] = t; //再把打出的牌放到桌上,即入栈
book[t] = 1; //标记桌上现在已经有牌面为t的牌
}
else
{
//player此轮可以赢牌
q1.head++;//player已经打出一张牌,所以要把打出的牌出队
q1.data[q1.tail] = t;//紧接着把打出的牌放到手中牌的末尾
q1.tail++;
while (s.data[s.top] != t) //把桌上可以赢得的牌依次放到手中牌的末尾
{
book[s.data[s.top]] = 0;//取消标记
q1.data[q1.tail] = s.data[s.top];//依次放入队尾
q1.tail++;
s.top--; //栈中少了一张牌,所以栈顶要减1
}
}
t = q2.data[q2.head]; //player2出一张牌
//判断player2当前打出的牌是否能赢牌
if (book[t] == 0) //表明桌上没有牌面为t的牌
{
//player2此轮没有赢牌
q2.head++; //player2已经打出一张牌,所以要把打出的牌出队
您可能关注的文档
- Android的界面设计-课程设计报告32.doc
- 5住宅楼施工组织设计及施工图预算.doc
- Android的界面开发课程设计报告5.doc
- Android登录界面-课程设计报告【数据库认定】3.doc
- android开发测试课程设计报告3.doc
- android模拟器--课程设计报告【数据库认证】.doc
- android开发设计-课程设计报告【数据库认定2】.doc
- Android数据库认定--课程设计报告.doc
- 毕业设计-Android用户登陆系统课程设计.doc
- Eclipse-软件测试课程设计报告2.doc
- 帕金森护理诊断.pptx
- 平面交通安全教育.pptx
- 2025河南郑州市社会福利院招聘公益性岗位人员1人笔试备考试题及答案解析.docx
- 2025湖南长沙市一中初级中学招聘教师13人笔试备考题库及答案解析.docx
- 年度员工述职报告.pptx
- 2025年度常熟农村商业银行校园招聘220人笔试备考题库及答案解析.docx
- 2025河南郑州市招生考试中心招聘公益性岗位人员7人笔试备考试题及答案解析.docx
- 2025内蒙古电力集团子公司招聘61人笔试备考试题及答案解析.docx
- 2025福建三明市第一医院招聘2人笔试备考题库及答案解析.docx
- 2025贵州观山湖区逸都国际学校春季学期招聘临聘教师笔试备考试题及答案解析.docx
最近下载
- 民用无人机驾驶员训练手册(供参考).doc VIP
- 今日头条机构入驻协议3篇.docx
- 肺部结节影的影像学诊断与鉴别诊断.ppt
- 2025年山东省青岛西海岸新区中考一模训练语文试题(含答案) .pdf VIP
- 民用无人机驾驶员训练手册(2020).docx VIP
- 人教PEP版(2024)三年级下册英语Unit 6 Numbers in life单元整体教学设计(共6课时).docx
- 国网电动汽车服务有限公司招聘笔试题库2022.pdf
- 自娱自乐攻略适用21.0211新春版 by龙行天下Iray.xlsx VIP
- 基于单片机的智能衣柜控制系统设计.docx
- 搅拌站沙石供应合同模板.docx VIP
文档评论(0)