欢迎来到天天文库
浏览记录
ID:28057144
大小:168.94 KB
页数:10页
时间:2018-12-07
《数据结构课程设计案例纸牌游戏》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、题目:纸牌游戏目录—>B求射斤3二、概要设计3三、详细设计4四、调试分析和测试结果7五、总结8六、参考文献8七、雜8八、附录9一、需求分析按以下规则进行翻牌:编号为1-52张牌,正面向上,从第2张开始,以2为基数,是2的倍数的牌翻一次,直到最后一张牌;然后,从第3张开始,以3为基数,是3的倍数的牌翻一次,直到最后一张牌;然后...从第4张开始,以4为基数,是4的倍数的牌翻一次,直到最后一张牌;...再依次5的倍数的牌翻一次,6的,7的直到以52为基数的翻过,最后输出正面向上的牌有哪些?用函数obvl、obv
2、2按照题目要求的规则,用for循环来实现.二、概要设计1.当从第二个编号开始的每张牌每次遇到是其倍数吋,都会相应的翻一次,这样,每张牌会翻的次数就各不一样,可能很多次,也可能只有一两次,而结果只是耍输出在经过各个不同次数的翻牌后,正面向上的牌都有哪儿张。比如24,第一次它是2的倍数时要从正而翻到背而,当进行到3时,就又要从背而翻回来,而到4时还要在翻,同理呢,到6.8.12…它都要来回的翻。如果它在多次的翻牌后,正面还向上了,那么它就是要输出的结果之一。2.建立代表52张牌的线性表一一调用翻牌算法按照规则翻
3、牌一一输岀翻牌算法的结果最为主要的翻牌算法的实现:voidobv2(SqListL,intn){for(inti=2;i<=n;i++)for(intj=i;j<=L.length;j++)if(jO/oi==0){if(L.data[j]==l)L.data
4、j]=0;elseif(L.data[jl==0)L.data[j]=l;}}以上是通过for循环对是当前基数倍数的牌进行翻牌3、根据算法思想,流程图如下:幵始建立一个线性表L,将所有变量赋初值为0,表示牌正面向上i>=2&&i<=52翻牌,如果L.
5、data[j]=l,则变为0翻牌,如果L.data[jl=0,则变为1输岀线性表中正面向上的牌的编号三、详细设计1、预处理#include#include#defineSIZE100//线性表存储空间的初始分配量2、数据类型定义定义一个结构体类型SqList,结构体中数组指针elem指示线性表的基地址,length指示线性表的当前长度。Listsize指示顺序表当前分配的存储空间大小,一旦因插入元素而空间不足时,可进行再分配。typedefstruct{int*e
6、lem;//存储空间基址int*data;intlength;//当前长度intlistsize;//当前分配的存储容景JSqList;3、主要函数功能介绍构造一个空的线性表L用来存储分配:voidInitList_Sq(SqList&L){//构造一个空的线性表L。L.elem=(int*)malloc(SIZE*sizeof(int));if(!L.elem)cout«"ERROR";//存储分配失败L.data=(int*)malloc(SIZE*sizeof(int));if(!L.data)cou
7、t«nERROR”;//存储分配失败L.length=0;//空表长度为0L.listsize=SIZE;//初始存储容量}//InitList一Sq调用PrintList_Sq函数用来显示线性表中的数据:voidPrintList_Sq(SqListL){//显示线性表中所有数据for(inti=l;i<=L.length;i++)if(L.data[i]==l)cout«L.elem[i]«"}cout«endl;}调用函数obvl,确保翻牌前每张牌都是正面向上:voidobvl(SqListL){fo
8、r(inti=l;i<=L.length;i++)L.data[i]=l;}调用函数obv2,按照规则翻牌:voidobv2(SqListL,intn){for(inti=2;i<=n;i++)for(intj=i;j<=L.length;j++)if(jO/oi==0){if(L.data[j]==l)L.data[j]=0;elseif(L.data[j]==0)L.data
9、j]=l;}}4、主函数voidmain(){SqListL;intn=52;InitList_Sq(L);for(inti=l
10、;i<=n;i++)L.elemfi]=i;L.Iength++;}obvl(L);obv2(L,n);cout«”正面向上的牌的编号是:n«endl;PrintList_Sq(L);}!1!调试分析和测试结果在编写程序时应该用规范化的格式输入源程序,同时注意不要忘了编写头文件#心11^<^^^111上〉、#include;在编程时不要忽略丫一些细节,不要忘了;、}等符号,否则程序将无法正常运
此文档下载收益归作者所有