已阅读5页,还剩14页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
成绩 课程设计报告 题 目 24点游戏 课 程 名 称 软件项目实践(二) 院 部 名 称 信息技术学院 专 业 计算机科学与技术 班 级 m11计算机科学与技术(专转本)学 生 姓 名 王蕾 学 号 1121412006 课程设计地点 校内实验室 课程设计学时 2周(40学时) 指 导 教 师 沈 奇 金陵科技学院教务处制1课程设计报告目录一、实验目的和要求1二、实验仪器和设备2三、实验过程2四、实验结果与分析16五、实验心得18 一、实验目的和要求1实验目的1) 了解并掌握数据结构与算法的设计方法,具备初步的独立分析和设计能力;2) 初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法和技能;3) 提高综合运用所学的理论知识和方法独立分析和解决问题的能力;4) 训练用系统的观点和软件开发一般规范进行软件开发。5) 培养快速学习新的知识,并在项目中使用的能力。2实验要求设计并实现24点游戏,满足以下基本要求: 运行系统后,用户登录,输入用户名后,可以进入游戏,或查看英雄榜。 玩家开始游戏后,系统随机产生四个1-13的数,分别代表13张牌。提示玩家输入算式。判断玩家输入的表达式是否合法,其中算式中的四个数字只能是程序所给的四个数字。当玩家正确输入算式后,运用“用堆栈求解表达式”的原理,求出结果并判断是否为24,得出用户是输是赢的结果。 如果用户赢,计算其所用时间(从输入算式开始计算,直至输入算式结束),并与英雄榜中成绩进行比较。可以进入英雄榜的,则需更新英雄榜。英雄榜只按成绩降序记录1-5名相关信息。二、实验仪器和设备microsoft windowsxp / windows 7turbo c/visual c+三、实验过程(一)项目计划 11 总体介绍 24点游戏是一种使用扑克牌来进行的益智的游戏,游戏内容为:从113中,任意抽取4张牌,运用加、减、乘、除和括号等运算符把牌面上的数进行运算得到24,每个数都必须运算,并且只能运算一次,运算符可多次重复使用。1.2 参考文献1算法与数据结构用c语言描述,唐策善编著,高等教育出版社 20082数据结构 (c语言版),严蔚敏等编著, 清华大学出版社 20043数据结构实用教程(第二版),徐孝凯编著,清华大学出版社 20064计算机程序设计技巧第一、三卷,d.e.knuth著,管纪文译,国防出版社5fundamentals of data structures,fulls horo-witz&sartaj sahnt6.数据结构基础(中译本),程惟宁译,新时代出版社(二)需求分析21 需求概述分析 1)输出的判定和四位数字的类型: 在输出的时候对最后结果等于24的判别,因为考虑到有除法,有可能中途 结果可能会出现不能整除的情况与小数,所以输出的四个数都设为float型,且输出判定的时候用近似判定法,而不直接写让最后结果等于24(详情见算法)。2)括号问题的处理: 对于括号问题,我规定对每一步的计算表达式,除了*之外,+,-,都加上括号,即让程序按自己规定的方向执行,输出的括号只是让人能看懂,其实在运算时不起作用(详情见算法)。22 输入输出的要求输入的运算符只能是+、-、*、/、(、)这六个,输入的整数必须是程序随机产生的那四个数,而且每个数只能用一次。23 概要设计 功能模块图24算法游戏随机发牌输入求解表达式计算表达式判断表达式的正误 (三)面向对象分析3.1 用例图 登入查看英雄榜用户用例图退出3.2 总体流程图 开始开始界面选择事件登入输入用户名和密码与数据库信息进行检测普通用户数据进入普通用户界面选择事件切换用户进入游戏退出游戏数据不存在退出退出查看英雄榜3.3游戏流程图开始进入游戏开始界面输入表达式计算是否=24?显示congratulationsery good显示input any key,hint answer.go on or exit ?退出nnyy(四)详细设计 4.1 界面要求 要求有合理的界面,用户可以读懂看清程序将要做的事情,并可以在一步一步的执行时可以有一些提示,这样用户可以继续使用。4.2 功能逻辑设计在设计这个程序之前,我把这个程序分为多块,它们分别为:1) 显示登录界面 玩家输入用户名和密码,进入游戏2) 显示游戏界面 随机产生4个数; 提示输入表达式; 玩家输入表达式,用栈存储起来; 判断输入是否合法,四个数是不是随机产生的四个; 给出结果。3) 显示游戏界面 用户根据提示,选择进入查看英雄榜; 4.3存储结构1)人算24点时:使用的是穷举法,对应一组数字,找出有可能的情况。 2)计算机算24点时:采用单链表作为存储结构,使用栈来进行表达式求值的原理实现。4.4使用说明例1:显示: 7 7 2 5 则您可以输入表达式: 2*5+7+7. 回车显示: congratulations 例2.显示: 3 12 2 6 则您可以输入表达式: 2*3+6+12.回车显示: congratulations例3. 显示:10 9 10 10则您可以输入表达式:?回车显示:input any key,hint answer.附: 1)当玩家不会游戏时,可以输入?,游戏会给出答案;但有的四个数字不能算出24点,所以直接进入下个游戏。2)游戏存在着许多不足之处,比如没有注册功能,没有管理员的功能,所以不能进行对用户的管理,修改,添加等操作。 (五)编码系统主要功能代码1) /*进入游戏*/void game()/*进入游戏*/ int i,j,k,t,again,res,flag;char c;float num4;again=1; clock_t start, finish;double duration,n;while(again=1) system(cls);printf(tt *n);printf(tt * *n);printf(tt * 24game *n);printf(tt * *n);printf(tt *n); printf(nntt ); srand(time(0); /*获取随机种子使得每次随机的值不同*/ for(i=0;i4;i+) numi=(float)(rand()%13); /*获取13以内的随机数值*/ for(i=0;i4;i+) printf(%2.0ft,numi); /*输出4个随机数值*/ printf(nn);start = clock(); self();/*自己算*/ finish = clock(); duration = (double)(finish - start) / clocks_per_sec; if(result=24) printf(tt congratulations!the correct answer.nn); if(j10) strcpy(herosj.name ,); strcpy(herosj.sex ,temp1.sex); herosj.time =duration; j+; else n=heros0.time; for(i=0;in) herosi.time=n; j=i; strcpy( ,); strcpy(herosj.sex ,temp1.sex); herosj.time =duration; input_hero(); /*向英雄榜文件里写入信息*/ else printf(tt input any key,hint answer.nn);c=getch();if(c) for (i=0;i4;i+) for (j=0;j4;j+) if (j!=i) for (k=0;k4;k+)if (k!=j & k!=i) for (t=0;t=0) if(pi=0&pi=0;) if(si=48 & si=f(stacktop) top+; stacktop=si; break; else pj=stacktop; top-;j+; if(si=() /*假如是开括号,栈中运算符逐个出栈并输出,直到遇到闭括号。闭括号出栈并丢弃。*/ while(stacktop!=) pj=stacktop; top-;j+; top-; i-; while(top!=0)/*假如输入完毕,栈中剩余的所有操作符出栈并加到输入串中*/ pj=stacktop; j+; top-; pj=0; i=-j; for(j=i;j=i/2;j-) char t; t=pj;pj=pi-j;pi-j=t; 6) /*用户自己算24点*/void self() char p100; char p1100; convert(p,p1); s s1; initial(s1); calculate(p1,s1);int treat(float a,float b,float c,float d) int i,j,k;float sum1,sum2,sum3;for (i=0;i4;i+) for (j=0;j6;j+) for (k=0;k6;k+) if(!(i=3&b=0)&(!(j=3&c=0)&(!(k=3 &d=0) sum1=myf(i,a,b); sum2=myf(j,sum1,c); sum3=myf(k,sum2,d); if(fabs(sum3-24)0.1) temp+; myprint(1,i,j,k,a,b,c,d); if(k=2) sum1=myf(i,a,b); sum2=myf(j,c,d); sum3=sum1*sum2;if(fabs(sum3-24)0.1) temp+; myprint(2,i,j,k,a,b,c,d); if(k=3) sum1=myf(i,a,b); sum2=myf(j,c,d); if(sum2!=0) sum3=sum1/sum2;if (fabs(sum3-24)0.1) temp+; myprint(3,i,j,k,a,b,c,d); if (temp=0) return 0;else return 1;float myf(int flag,float m,float n)if(flag=0) return (m+n);if(flag=1) return (m-n);if(flag=2) return (m*n);if(flag=3) if(n=0) return 30000; else return (m/n);if(flag=4) return (n-m);if(flag=5) if(m=0) return 30000; else return (n/m);return 0;void myprint(int type,int i,int j,int k,float a,float b,float c,float d)char sigle6; sigle0=+; sigle1=-; sigle2=*; sigle3=/; sigle4=-; sigle5=/;if(type=1) if(j=4 | j=5) if (k=4 | k=5) printf(tt %2.0f %c (%2.0f %c (%2.0f %c %2.0f) =24n,d,siglek,c,siglej,a,siglei,b);else printf(tt (%2.0f %c (%2.0f %c %2.0f) %c %2.0f =24n,c,siglej,a,siglei,b,siglek,d); else if(k=4 | k=5) printf(tt %2.0f %c (%2.0f %c %2.0f) %c %2.0f) =24n,d,siglek,a,siglei,b,siglej,c); else printf(tt (%2.0f %c %2.0f) %c %2.0f) %c %2.0f =24n,a,siglei,b,siglej,c,siglek,d); if(type=2 | type=3) printf(tt (%2.0f %c %2.0f) %c (%2.0f %c %2.0f) =24n,a,siglei,b,siglek,c,siglej,d);四、实验结果与分析1 系统各模块的运行界面(1) 运算正确:(2) 没有运算结果(3) 运算错误:2系统性能分析 通过该游戏系统,我们将以前人们通过手动算24点的游戏通过电脑来实现,电脑随机出牌,用户通过运算,在用户输入的时候,电脑会自动计时,通过对不同用户的游戏时间记录,来产生英雄榜,方便快捷。由于人员有限,该系统我们只编写了主要程序部分,对于游戏的注册及管理员的功能都尚未实现,有待改进和提高。五、实验心得通过这次课程设计,我收获很多。课程设计是培养学生综合运用所学知识,发现,提出,分析和解决实际问题,锻炼实践能力的重要环节,是对学生实际工作能力的具体训练和考察过程。随着科学技术的不断发展,计算机在我们日常生活中无处不在,作为21世纪的大学生,学好计算机开发技术是非常重要的。我们应该紧随时代的步伐,不断地注入新的活力,才能不被社会淘汰。回顾这次课程实际,我感慨颇深,刚开学老师布置这个课题时,我满心疑问,不知从何入手,随着c语言和数据结构的慢慢学习深入,我懂得了很多东西,比如入栈,出栈,中缀和后缀的转换等等。将近一个月的课程设计中,我学会了很多东西,不仅巩固了之前所学,而且还学到了很多课本上没有学过的知识。通过这次课程设计,使我更加明白理论与实践相结合的重要性。“纸上得来终觉浅,绝知此事要躬行”,只有自己亲身去实践,我们才会有所得,有所会。在
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 沈阳理工大学《管理统计学》2021-2022学年第一学期期末试卷
- 沈阳理工大学《单片机原理与接口技术》2022-2023学年期末试卷
- 广东外语外贸大学 研究生 定向 合同
- 合同标签替换规范
- 共享单车管理
- 2024货船租赁合同
- 绿化养护工程XX管养项目投标文件
- 2024物流运输合同格式
- 2024广西无公害稻米种植收购合同范本
- 2024打印机复印机销售合同
- 《分物游戏》说课
- 多媒体信息编码及处理课件
- (完整版)虬髯客传课件
- 石油化工集团公司绩效考核管理规定
- 外贸英语口语(课堂PPT)课件(PPT 92页)
- 建筑工程施工安全检查表范本
- 白银区省级中小学学科带头人和骨干教师评选工作方案[管理资料]
- 部编版三年级道德与法治下册第11课《四通八达的交通》优质课件(含视频)
- 高速公路监控摄像机太阳能供电系统
- 仪表验收检查表
- 全国中学生数学能力竞赛组织委员会
评论
0/150
提交评论