数据结构设计报告纸牌游戏
纸牌游戏—数据结构实训代码
纸牌游戏——数据结构实训代码实训要求:基本要求:一副没有花牌(J、Q、K、A、大小王)的扑克牌,两个人进行纸牌游戏,其中一个人为用户,另一个人为计算机;每轮每人各发 5 张牌,各自以这 5 张牌建立二叉排序树;由用户先出,轮流出牌,每次只能出一张并且要比别人出的大,如:用户出3,计算机则要出比 3 大的牌,没有则选择不出;最先出完的人获胜。
#include <iostream>#include<stdlib.h> // 产生随机数#include<time.h>#include <Windows.h>#include <iomanip>using namespace std;class PlayingCards{private:int card1[10][4];//标记发牌int card2[5][2];//标记出牌public:int b[5];char bhuase[5];int c[5];char chuase[5];PlayingCards(){};void yxsm(); //游戏说明void fp();//随机发牌void cp();//按顺序出牌,并显示void xswj();//显示获得的牌void xsdn();//显示获得的牌void qk();//清空标记数组的记录};PlayingCards a;typedef struct node{int data;struct node * LChild;struct node * RChild;}node;class tree{private:int data;struct node * LChild;struct node * RChild;public:void chushihua(node *t);node * charu(node *t , int key);node * jianlib(node *t);node * jianlic(node *t);void paixu1(node * t);void paixu2(node * t,int *p);void paixu3(node * t,int *p);};tree tr;void PlayingCards::yxsm(){cout<<" "<<"每轮每人各发5 张牌,各自以五张牌建立二叉树,由用户先出,轮流出牌,"<<endl;cout<<" cout<<" cout<<" } "<<"每次只能出一张并且要比别人出的大,"<<endl;"<<"如:用户出3,计算机则要出比3 大的牌,没有则选择不出;"<<endl; "<<"最先出完的人获胜。
数据结构与算法课设-纸牌游戏21点
目录备注: (2)一、游戏简介 (2)二、设计要求 (2)2.1 问题描述 (2)2.2 要求分析 (2)三、程序功能 (3)3.1 程序的主要功能描述 (3)3.2序流程图 (3)3.3主界面 (4)3.4功能测试 (4)四、源程序 (6)五、课设心得 (14)备注:由于这次课设开始时以为可以做其他题目,知道周四才知道不行。
但我的21点一几个基本成型,因此没有继续改动,希望老师能够理解。
一、游戏简介又名黑杰克,起源于法国,现已流传到世界各地。
现在在世界各地的赌场中都可以看到二十一点,随着互联网的发展,二十一点开始走向网络时代,比如菲律宾的博彩公司就有该游戏。
该游戏由 2 到 6 个人玩,使用除大小王之外的52 张牌,游戏者的目标是使手中的牌的点数之和不超过 21 点且尽量大。
有着悠久的历史。
1700年左右法国赌场就有这种21点的纸牌游戏。
1931年,当美国内华达州宣布赌博为合法活动时,21点游戏第一次公开出现在内华达州的赌场俱乐部,15年内,它取代掷骰子游戏,而一举成为非常流行的赌场庄家参与的赌博游戏。
二、设计要求编写程序实现游戏,该程序是模拟古老的“21点纸牌游戏”,实现一对一的人机大战。
要求游戏过程中任意一方牌的点数之和超过 21 点,则自动出局;在不超过 21 点的情况下,玩家下注由电脑随机发牌与庄家比累积牌的点数的大小,大者为赢家。
2.1 问题描述本次C++课程设计题目是“21点纸牌游戏”,系统的主要功能是娱乐游戏,有电脑和玩家一起玩这个游戏,玩家设法使自己的牌达到总分21并要比电脑开的点数大而且不超过这个数值。
扑克牌的分值取它们的面值。
J,Q,K分别是11, 12和13分。
2.2 要求分析编写程序实现游戏,该程序是模拟古老的“21点纸牌游戏”,实现1对1的人机大战。
要求游戏过程中任意一方牌的点数之和超过21点,则自动出局;在不超过21点的情况下,玩家下注由电脑随机发牌与庄家比累积牌的点数的大小,大者为赢家。
数据结构课程设计报告—纸牌游戏
课题设计2:扑克牌游戏1、问题描述编号为1-52张牌,正面向上,从第2张开始,以2为基数,是2的倍数的牌翻一次,直到最后一张牌;然后,从第3张开始,以3为基数,是3的倍数的牌翻一次,直到最后一张牌;然后…从第4张开始,以4为基数,是4的倍数的牌翻一次,直到最后一张牌;...再依次5的倍数的牌翻一次,6的,7的直到以52为基数的翻过,输出:这时正面向上的牌有哪些?存储结构:源程序:#include <stdio.h>void main(){int i,j,a[52];for(i=2;i<=52;i++)for(j=i-1;j<52;j+=i)a[j]=!a[j];printf("正面向上的牌有:");for(i=0;i<52;i++)if(a[i])printf("%4d",i+1);}测试结果:正面向上的牌有:1 4 9 16 25 36 49算法的时间复杂度:T(n)=O(n2)课题设计3:joseph环一. 需求分析:利用单向循环链表存储结构模拟此过程,按照出列的顺序输出各个人的编号。
首先创建一个空链表,初始化链表,构造出一个只有头结点的空链表,建立好一个约瑟夫环。
1. 输入的形式和输入值的范围本程序中,输入报数上限值m和人数上限l,密码,均限定为正整数,输入的形式为一个以“回车符”为结束标志的正整数。
2. 输出的形式从屏幕显示出列顺序。
3. 程序功能提供用户从键盘输入,Joseph约瑟夫环的必要数据,并显示出列顺序。
二、概要设计以单向循环链表实现该结构。
1. 抽象数据类型的定义为:ADT LNode{数据对象:D={ai | ai∈CharSet,i= 1,2,…,n,n≥0}数据关系:R1={< ai-1 ,ai > | ai ∈D,I=2,…,n} 三.源程序:#include<stdio.h>#include<stdlib.h>typedef struct Node{int key;//每个人持有的密码int num;//这个人的编号struct Node *next;//指向下一个节点}Node,*Link;void InitList(Link &L) //创建一个空的链表{L=(Node *)malloc(sizeof(Node));if(!L) exit(1);L->key=0;L->num=0;L->next=L;}void Creater(int n,Link &L) //初始化链表{Link p,q;q=L;for(int i=1;i<=n;i++){p=(Node *)malloc(sizeof(Node));if(!p) exit(1);printf("the key_%d is:",i);scanf("%d",&p->key);p->num=i;L->next=p;L=p;}L->next=q->next;free(q);}void main(){Link L,p,q;int n,x;L=NULL;InitList(L);//构造出一个只有头结点的空链表printf("please input the totle number of people:"); scanf("%d",&n);//总共的人数nprintf("the start key is:");scanf("%d",&x);//初始密码为xCreater(n,L);//建立好一个约瑟夫环p=L;for(int i=1;i<=n;i++){for(int j=1;j<x;j++)p=p->next;q=p->next;x=q->key;printf("%d ",q->num);p->next=q->next;free(q);}}四、测试数据:m的初值为20,n=7 ,7个人的密码依次为3,1,7,2,4,7,4输出:6 7 4 1 5 3 2课题设计4:商品货架管理1、需求分析:设计一个算法,每一次上货后始终保持生产日期越近的商品越靠近栈底。
纸牌游戏实验报告
纸牌游戏实验报告篇一:纸牌游戏Go Fish实验报告纸片游戏Go Fish课程设计一目的通过对GO FISH的课程设计,明白数据结构设计理念,理解并掌握链表的操作,进一步的了解数据结构的含义。
二需求分析决定玩家的数量,先简单化,建立两个玩家,完成设计;1、确定数据结构模版;2、建立数据结构类型;3、完成数据操作;4、确立算法设计。
三概要设计1、数据结构设计该课程设计采用链表和类相结合模式,建立牌堆和牌操作的链表结构:class Card{public:};牌堆类:采用整型数组建立牌堆,并用随机数打乱牌序。
class Node{public:Node(); Node(int value,Node *next);//初始化节点构造函数 int ListLength(Node* L); //链表的计数 int Search(Node* L , int num); //链表的查找Node* head_Insert(Node* head , int num);//从表头插入节点Node* Delete(Node* head , int num); //删除节点 void Print(Node *head);//链表输出 int card_num; char clore; Node *Link; void NewCard();//新建牌 void Shuffle();//洗牌int Licensing(int n);//发牌int CARD_A[52]; private: private:采用链表结构方式,来构造玩家手牌。
用链式结构进行操作进行删除和插入。
2、算法函数int Scoring(NodePtr &player,int score)//计分;int Players_operations(NodePtr &player1,NodePtr &player2,int Choose,int i,Card CardBign)//玩家操作;两个函数分别用来计算与进行牌的操作。
纸牌游戏课程设计
攀枝花学院课程设计题目:纸牌游戏的设计与实现院(系):年级专业:姓名:学号:指导教师:二〇〇九年十二月十四日攀枝花学院教务处制攀枝花学院本科学生课程设计任务书注:任务书由指导教师填写。
摘要纸牌游戏是数据结构大作业中比较经典的一个大作业,通过此课程设计能够启发我们的思维,对数据结构中的函数有更加清楚的认识,建立我们对数据结构的兴趣,通过此课程设计设同时也能够使我们对各方面的知识有了更加全面的认识与了解,丰富了我们的知识面,扩展了我们的思维。
通过课程设计的实践,我们可以在程序设计方法、上机操作等基本技能和科学作风方面受到比较系统和严格的训练。
当前计算机软件技术和网络技术正飞速发展,软件系统日趋大型化、复杂化,软件对于一个计算机系统是至关重要的。
因此社会对软件开发者提出了比以往更高的要求,相应的系统要求也有了很大的提高。
本系统用C++作为程序语言,设计出的系统功能强大,操作方便灵活。
关键词纸牌游戏,数据结构,软件,系统-Ⅰ-目录摘要 (Ⅰ)1需求分析 (1)1.1需求来源 (1)1.2设计目的 (1)1.3设计要求 (1)2 功能需求描述 (1)3 总体设计 (1)3.1设计思想 (1)3.2系统模块结构 (2)3.3 系统总设计流程图 (2)4 概要设计 (4)4.1抽象数据类型定义 (4)4.2本程序所包含模块 (5)4.3系统功能的实现 (5)5 模块设计 (6)5.1洗牌模块 (6)5.2翻牌模块 (6)6 运行与分析 (6)6.1运行结果 (6)6.2结果分析 (7)致谢 (8)参考文献 (9)源程序 (10)1 需求分析1.1需求来源在本系统的需求分析环节中,会对软件开发的意图、开发的目标、作用范围和有关该软件开的背景材料进行详细的分析。
纸牌游戏作为一个用来娱乐的应用软件,在对其进行需求分析的过程中,需用要充分考虑系统的可用性和简单易用性,联系实际娱乐需要,从而得到合理的需求分析结论。
1.2设计目的该软件为用户提供一个在Windows系统上运行的纸牌游戏小系统。
纸牌游戏—数据结构实训报告
纸牌游戏—数据结构实训报告纸牌游戏—数据结构实训报告1. 项目背景和介绍1.1 项目背景在现代社会中,人们经常通过玩各种纸牌游戏来娱乐和消遣。
纸牌游戏可以帮助人们放松身心、提高思维能力和判断力。
为了更好地理解纸牌游戏的规则和操作方法,并掌握数据结构的应用,我们决定开展这个纸牌游戏的数据结构实训项目。
1.2 项目目标本项目的目标是设计并实现一个纸牌游戏系统,包括纸牌的洗牌、发牌和玩家的操作等。
通过这个项目,我们将学习和提高对数据结构的应用能力,同时也能够提高我们团队合作和项目管理的能力。
2. 需求分析2.1 功能需求2.1.1 纸牌洗牌功能实现纸牌的洗牌功能,确保每次发牌的牌都是随机的,避免出现重复或排序的情况。
2.1.2 纸牌发牌功能实现纸牌的发牌功能,能够按照规则将纸牌发给玩家,并保持每位玩家手中的牌都是不同的。
2.1.3 玩家操作功能实现玩家在游戏中的各种操作,如出牌、抽牌、跳过等,并能够根据规则进行相应的判断和处理。
2.1.4 游戏结束功能实现游戏的结束判断功能,当有玩家出完所有手牌时,游戏结束。
2.2 性能需求2.2.1 系统响应速度系统应能够在合理的时间内响应用户的操作,确保用户能够顺畅地进行游戏。
2.2.2 系统可扩展性系统应具备良好的可扩展性,方便后续的功能迭代和升级。
3. 系统设计3.1 数据结构设计3.1.1 纸牌数据结构设计设计一种合适的数据结构来表示一副纸牌,包括牌的花色、点数等信息,并能够支持洗牌、发牌和玩家操作等功能。
3.1.2 玩家数据结构设计设计一种合适的数据结构来表示玩家的手牌、出牌等信息,并能够支持玩家操作功能。
3.2 算法设计3.2.1 洗牌算法设计设计一种高效的洗牌算法,确保洗牌后每张牌的位置都是随机的。
3.2.2 发牌算法设计设计一种合理的发牌算法,保证每位玩家获得的牌都是不同的。
3.2.3 玩家操作算法设计设计一种算法来判断玩家的操作是否合法,并根据规则进行相应的处理。
纸牌游戏Go-Fish实验报告
CARD_A[i]=i;
}
洗牌操作,用随机数实现对数组的打乱操作:
void Card::Shuffle()
{ 中南民族大学计算机科学学院
专业 :软件工程 学 8
号:2012213660 姓名 :唐洁
int F_num,L_num; srand((int)time(NULL)); for(int i=0;i<52;i++) {
int Licensing(int n);//发牌
private:
int CARD_A[52];
};
class Node
{
public:
Node();
Node(int value,Node *next);//初始化节点构造函数
int ListLength(Node* L); //链表的计数
int Search(Node* L , int num); //链表的查找
专业 :软件工程 学 1
号:2012213660 姓名 :唐洁
牌堆类:采用整型数组建立牌堆,并用随机数打乱牌序。 class Node { public:
Node(); Node(int value,Node *next);//初始化节点构造函数 int ListLength(Node* L); //链表的计数 int Search(Node* L , int num); //链表的查找 Node* head_Insert(Node* head , int num);//从表头插入节点 Node* Delete(Node* head , int num); //删除节点 void Print(Node *head);//链表输出 private: int card_num; char clore; Node *Link; }; 采用链表结构方式,来构造玩家手牌。用链式结构进行操作进行 删除和插入。
数据结构课程设计纸牌游戏
数据结构课程设计纸牌游戏一、课程目标知识目标:1. 学生能理解数据结构中栈和队列的基本概念及其在实际问题中的应用。
2. 学生能运用所学知识,设计并实现一个基于栈和队列的纸牌游戏。
3. 学生掌握栈和队列的操作原理,如入栈、出栈、入队、出队等基本操作。
技能目标:1. 培养学生运用数据结构解决实际问题的能力,提高编程技能。
2. 培养学生团队协作能力,通过小组合作完成纸牌游戏的设计与实现。
情感态度价值观目标:1. 学生能积极主动参与课程学习,培养对数据结构的兴趣和热情。
2. 学生在合作过程中,学会相互尊重、沟通与协作,培养良好的团队精神。
3. 学生通过解决实际问题,体会数据结构在实际应用中的价值,提高对计算机科学的认识。
课程性质:本课程为信息技术课程,以实践操作为主,结合理论讲解,帮助学生掌握数据结构的基本知识。
学生特点:学生为高中生,具备一定的编程基础和逻辑思维能力,对实际操作有较高的兴趣。
教学要求:教师需引导学生将所学知识应用于实际问题的解决,注重培养学生的动手能力和团队协作能力,使学生在实践中掌握数据结构的应用。
通过本课程的学习,学生应能够达到上述课程目标,实现具体的学习成果。
二、教学内容本课程教学内容主要包括以下几部分:1. 栈和队列的基本概念与性质- 栈的定义、特点及应用场景- 队列的定义、特点及应用场景- 栈与队列的异同点分析2. 栈和队列的操作原理- 栈的入栈、出栈操作- 队列的入队、出队操作- 栈与队列在实际问题中的应用案例分析3. 纸牌游戏设计与实现- 纸牌游戏规则设计- 使用栈和队列实现纸牌游戏的核心功能- 游戏界面设计及交互操作4. 编程实践- 使用教材指定的编程语言(如C++、Java等)进行编程实践- 学生分组合作,完成纸牌游戏的设计与实现- 教师指导与反馈,帮助学生优化代码和解决问题教学内容根据课程目标制定,注重科学性和系统性。
教学进度安排如下:1. 第1课时:栈和队列的基本概念与性质2. 第2课时:栈和队列的操作原理3. 第3课时:纸牌游戏规则设计4. 第4-6课时:编程实践,分组完成纸牌游戏设计与实现5. 第7课时:成果展示与评价,教师反馈与总结教学内容与教材关联紧密,旨在帮助学生将所学知识应用于实际问题解决,提高编程实践能力。
数据结构__扑克牌发牌问题[1]
内容:问题重述:设计一个四个人玩的纸牌游戏的程序,一共有五十四张牌,要发给四个人,并且每次发出的牌都不一样。
并且符合纸牌的规则(可以是桥牌、升级、红四、斗地主等,但是必须说明规则)。
并且程序能按照设定的游戏规则从小到大进行排序,如果有底牌的话要说明底牌的情况。
最后要验证每次发牌是否合法。
该程序纸牌的玩法:在一副牌中,去除大小王,然后2最大其次是A,然后按顺序从大到小一次减小。
所用到的具体算法:冒泡法,线性表删除元素操作;具体做法为:先将一副扑克牌中的大小王拿掉,还会剩下52张牌,在进行随机的洗牌,将所有的排顺序打乱,然后在打乱后一定的顺序情况下,按照规则平均分发给四个人,每人会得到十三张牌,最后将每人手里的牌按照3、4、5、6、7、8、9、10、J、Q、K、A、2的顺序进行排列,在排列过程中会出现花色的前后顺序排列。
再将四个人手里的拍验证,检验是否每张牌是否都出现并且只出现一次。
如果出现并且只出现一次,说明程序成功,否则程序失败,则需要重新进行程序的检验,修改。
流程图大致情况:设计的结构体变量说明:char CardColor是存储花色的变量char CardNumber[2]是存储扑克牌的面值变量int flag;//判断标志struct pukepai Card[52]用char类型存储52张扑克牌int card[52]用int类型形式并且,我们在一开始定义每张牌的变量每张牌现在我们给予赋值,例如108代表方块8,212代表红桃Q,其中三位数中第一为代表花色:1代表方块,2代表红桃,3代表梅花,4代表黑桃。
01代表A,02代表2,依次类推,11代表J,12代表Q,13代表K。
具体的函数说明均在程序中标注,不再重复说明。
程序执行结果为:1.2.3.结论:通过以上多次程序运行,满足了多次结果不相同,并保证每次都会有所有的排出现且仅出现一次。
遇到的问题:对一些代码的含义不太清楚,用起来不太熟练。
纸牌游戏设计报告
题目:(纸牌游戏)编号为 1~52张牌,正面向上,从第二张开始,以2为基数,是2的倍数的牌翻一次,直到最后一张牌;然后从第三张牌开始,以3为基数,是3的倍数的牌翻一次,直到最后一张牌;直到以52为基数的翻过,输出:这时输出正面向上的牌有哪些?一、问题分析及任务定义1、此程序需要完成如下要求:有已编号的1〜52张牌且正面朝上,从第二张牌开始,以2为基数,是2的倍数的牌翻一次,直到最后一张牌;直到以52为基数的牌翻过,要求最后输出所有正面向上的牌的编号。
2、任务定义:实现本程序需要解决以下几个问题:①如何存储52张牌,所选择的存储结构要便于实现题给要求的操作。
②如何设计翻牌程序。
③一张牌可能一次未翻,也可能翻多次,在经过所有的翻牌以后,如何知道每一张牌是否为正面向上。
④输出所有正面向上的牌的编号。
本问题的关键在于选择合适的数据结构存储52张牌,难点在于在所选的数据结构下实现题给要求的翻牌操作。
另一个难点在于所有的牌都进行了翻牌操作后,如何知道每一张牌是否为正面向上。
首先我们可以从实际生活中的操作来探讨第二个难点的解决思路。
编号为1的牌没有进行翻牌,即翻牌的次数为0,仍然为正面朝上;编号为 2的牌在整个过程中只翻了一次,为反面朝上;编号为 3的牌在整个过程中只翻了一次,为反面朝上;编号为4的牌在整个过程中翻了两次,为正面朝上;编号为 5的牌在整个过程中翻了一次,为反面朝上;编号为6的牌在整个过程中翻了三次(由于 6是2、3、6的倍数),为反面朝上;以此类推直至编号为52的牌,从上述过程可以总结出这样的规律:从编号为1的第一张牌到编号为 52的最后一张牌,只要它翻过的次数为偶数则是正面朝上,反之则为反面朝上。
因此我们可以依据每张牌翻过的次数来确定它最终是否为正面向上,从而输出实验所需要的结果:所有正面向上的牌的编号。
3、原始数据的输入、输出格式:由于本程序简单明了,不需要有任何的数据输入,只须用户选择执行或不执行此程序,若执行此程序,在程序运行后便可直接在运行结果窗口中看到所有正面朝上的牌的编号,这些编号数据均为整型;若不执行该程序则选择退出。
数据结构课程设计报告-纸牌游戏
3.2错误分析在初次编写完成后出了一些语法和拼写上的小错误,导致运行结果不正确。
例如翻牌子程序中的用到了for循环:for(int i=2;i<k;i++) ,编译时没有错误,经验证,编号第52的牌应为反面朝上,因此上述运行结果并不正确。
于是我开始一句句研究代码,发现是循环条件出错了,应该为for(int i=2;i<=k;i++)。
出现这个错误是自己很大意,仿造上面的创建链表时的循环条件没有添加等于号而出错了。
这也警示我在编写代码时要边写边思考,防止出现大的错误。
3.3运行程序进入主界面后,用户可以根据窗口提示得到想要的结果。
即输入Y则运行该程序,得到所有正面朝上的牌的编号,输入Q则不运行该程序,退出运行窗口。
程序开始运行,进入界面,如图3所示。
图3程序开始界面用户想要执行程序,选择Y,进入下一界面,如图4所示。
图4执行程序界面用户不想要执行程序,选择Q,进入的界面,如图5所示。
图5不执行程序界面4设计体会设计一个程序需要按一个完整的步骤来进行。
首先必须弄懂程序要解决的是什么问题。
在弄懂之后大脑中就要开始构思要用是什么方法来解决问题,在此期间需要“不择手段”,就是可以问同学、老师或者查阅相关资料通过网络等等,动用一切渠道把握别人的精髓来解决问题。
完成后就要把方法赋之于行动,主要是画出流程图和结构图,依照图设计出解决问题的各种算法随后编写出程序。
最后完成调试和纠错。
这方,都觉得挺高兴的,只有经过这个过程才会提高自己的发现问题、分析问题、解决问题的能力,使得思维更加严谨。
虽然这次课程设计不是很难,不是做一个比较大的系统,代码不算多,但是我认为要成功地完成一个程序,包括完整的实验报告都要投入必要的时间和精力,认真对待,这样我们可以收获不少东西。
在这次程序设计中,遇到了许多的问题,深知自己学习的知识还远远不够。
这是一种全面综合训练,是与课堂听讲,自学和练习相辅相成的,必不可少的一个教学环节。
数据结构大作业-纸牌游戏程序
/*任务:编号为1-52张牌,正面向上,从第2张开始,以2为基数,是2的倍数的牌翻一次,直到最后一张牌;然后,从第3张开始,以3为基数,是3的倍数的牌翻一次,直到最后一张牌;然后…从第4张开始,以4为基数,是4的倍数的牌翻一次,直到最后一张牌;...再依次5的倍数的牌翻一次,6的,7的直到以52为基数的翻过,输出:这时正面向上的牌有哪些?*/ #include <iostream.h>struct card{int num;int state;card *next;};void playCard(){int i;card*first=new card;card *p=first,*q;for(i=1;i<=52;i++){q=new card;q->num=i;q->state=1;//正面向上p->next=q;p=q;}p->next=NULL;p=first;for(i=2;i<=52;i++){p=first;for(int a=0;a<i;a++){p=p->next;}while(p!=0){if(a%i==0){p->state=p->state*(-1);//反向}p=p->next;a++;}}p=first;cout<<"这时正面向上的牌有:"<<endl; while(p!=0){if(p->state==1)cout<<p->num<<" ";p=p->next;}cout<<endl;}void main(){playCard();}#include "iostream.h"#include "stdlib.h"#define OK 1#define ERROR 0#define LIST_INIT_SIZE 100 //线性表存储空间的初始分配量#define LISTINCREMENT 10 //线性表存储空间的分配增量typedef int Status;typedef int ElemType;typedef struct{ElemType *elem; //存储空间基址int *data;int length; //当前长度int listsize; //当前分配的存储容量}SqList;Status InitList_Sq(SqList &L) {// 算法2.3// 构造一个空的线性表L。
纸牌游戏课程设计
课程设计报告课程名称数据结构课题名称纸牌游戏专业通信工程任务书下达日期2014 年 6 月16 日任务完成日期2014 年 6 月22 日目录一、需求分析 (3)二、概要设计 (3)三、详细设计 (3)四、调试分析 (7)五、用户使用说明 (7)六、测试结果 (7)七、总结 (8)八、附录 (8)课题名称纸牌游戏1. 需求分析1.1 运行程序后,便会显示出正面朝上的牌的编号。
所以需要程序能够储存1.2 显示出这52张牌中翻动次数最多与最少的牌,以及翻动的次数和是正面向上还是反面向上,需要程序能够自动计数自行比较并且输出的功能。
2.概要设计2.1 编号为1-52张纸牌,则需要创建一个线性表,运用malloc函数申请内存空间,存储纸牌编号信息。
2.2 设计翻牌程序,存储最后正面向上的牌的编号,和翻动次数最多的牌号,和翻动次数最少的牌号,以及他们翻动的次数,和他们是正面向上还是反面向上。
2.3 编写主函数,输出全部纸牌编号与程序的运行结果,让用户能够看到直观的求解结果。
3. 详细设计3.1创建线性表存储所有的纸牌编号typedef struct //定义线形表{int data[52];}list;void build(list* &l) //建立线形表{int i;l=(list*)malloc(sizeof(list));for(i=0;i<52;i++){l->data[i]=0;}3.2 建立fanpai() 函数void fanpai(list* &l){int j,i;for(j=2;j<=52;j++){for(i=1;i<=52;i++){if((i*j<=52)&&(l->data[i*j-1]==1)){l->data[i*j-1]=0;k[i*j-1]++;continue;}if((i*j<=52)&&(l->data[i*j-1]==0)){l->data[i*j-1]=1;k[i*j-1]++;continue;}}}printf("正面朝上的牌有:");for(j=0;j<52;j++){if(l->data[j]==0)printf(" %d ",j+1);}3.3 建立zuiduo()函数void zuiduo(list* &l){int b=k[0],j;for(j=0;j<51;j++){if(b<k[j+1]){b=k[j+1];}}printf("\n翻牌次数最多的是:\n");for(j=0;j<52;j++){if(b==k[j]){if(l->data[j]==0)printf("%d,次数为%d.正面\n",j+1,b);elseprintf("%d,次数为%d.反面\n",j+1,b);}}}3.4 建立zuishao()函数void zuishao(list* &l){int b=k[1],j;for(j=1;j<52;j++){if(b>k[j+1]){b=k[j+1];}}printf("翻牌次数最少的是:\n");for(j=0;j<52;j++){if(b==k[j]){if(l->data[j]==0)printf("%d,次数为%d.正面\n",j+1,b);elseprintf("%d,次数为%d.反面\n",j+1,b);}}}3.5 定义main()主函数int main(){list* a;build(a);int j=0;void change(list* &l); //翻牌void more(list* &l); //翻动次数最多void less(list* &l); //翻动次数最少change(a);printf("\n");more(a);printf("\n");less(a);printf("\n");return 0;}4.调试分析刚开始使用链表来存储数据,但是发现函数太过复杂而且有不可调节的错误。
数据结构课程设计环拓扑排序和纸牌游戏 (1)
目录课题一 joseph环 41.1 问题的提出1.1.问题的提出41.2 概要设计2.1算法思想51.3流程图根据算法思想,画程序流程图如下:661.4 源代码1.3.详细设计 7 输入m 、nm>0且n>0的整数建立含n 个结点的链表且用head 指向第一个元素,结点数据域包含password 、No 、以及指向下一结点的指head=>pn ≥2(m%n)==0?n:m%n=>1=>i i<mp →next=>pi++输出p →Nop →password=>m删除p 所指向结点n--输出p →No结束开始1.5 结果与分析.4 测试及性能分析10课题二拓扑排序 112.1 问题的提出2.1 问题的提出112. 2 概要设计112.3 流程图2.根据算法思想,画流程图如下:1212 开始设辅助数组indegree 记录图的各顶点的入度值,并将indegree 数组各变量赋初值。
输入图的顶点数、边数建立一个栈,存储图的顶点的序号用邻接表法建图,并计算出indegree 数组中各变量值根据indegree 数组将入度为0的顶点入栈count 对输出顶点计数0=>count栈不空删除栈顶元素,赋给i count++将与第i 个顶点链接的各顶点入度减1输出第i 个顶点值 顶点入度为0 顶点序号入栈count<G.vexnum输出“拓扑排序成功” 输出“拓扑排序不成功” 结束2.4 源代码132.5 结果与分析2.4 测试及性能分析17课题三纸牌游戏 193.1 问题的提出.1 问题的提出193. 2 概要设计191.当每个号码每次遇到是某个数的倍数时,都会相应的翻一次,这样,每张牌会翻的次数就各不一样,可能很多次,也可能只有一两次,结果就只是要输出在经过各个不同次数的翻牌后,正面向上的牌都有哪几个。
举例说明一下,比如24,第一次它是2的倍数时要从正面翻到背面,当进行到3时,就又要从背面翻回来,而到4时还要在翻,同理呢,到6.8.12…它都要来回的翻。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
/
纸牌游戏
一.需求分析
1.编号为1-52张牌,正面向上
2. 从第2张开始,以2为基数,是2的倍数的牌翻一次,直到最后一张牌;然后,从第3张开始,以3为基数,是3的倍数的牌翻一次,直到最后一张牌;然后从第4张开始,以4为基数,是4的倍数的牌翻一次,直到最后一张牌;...再依次5的倍数的牌翻一次,6的,7的直到以52为基数的翻过
3. 输出:这时正面向上的牌;
4.测试数据
52张牌
二.概要设计
-
1.数组抽象数据类型定义:
ADT SqList{
数据对象:ji=0,…,bi-1,i=1,2,…,n,
D= {aj1j2…jn|n(>0)称为数组的维数,bi是数组第i维的长度, ji是数组第i 维的下标, aj1j2…jn∈ElemSet}
数据关系:R={R1,R2,…,Rn}
Ri={<aj1…ji…jn,aj1,…ji+1,…jn>|0≤jk≤bk-1,1≤k≤n且k≠I, 0≤ji≤bk-2, aj1…ji…jn,aj1,…ji+1,…jn∈D,i=2,…,n}
基本操作:
faceringt(L):
~
操作结果:对纸牌进行翻转
} ADT SqList
2.本程序包含两个模块:
(1)主程序模块
void main()
{定义一个二叉树;
for(i=1;i<=52;i++)
{ [i].num=i;
—
[i].visit=0;
{
for(i=2;i<=52;i++) um%i==0) isit==0) isit=1;
else
[j].visit=0;
}
}
?
for(i=1;i<=52;i++) isit==0)
cout<<[i].num<<" ";
}
cout<<endl;
}
3. 主函数
void main()
{
¥
for(i=1;i<=52;i++)
{
[i].num=i;
[i].visit=0;函数的调用关系反映了演示程序的层次结构
主程序
faceringt
)
四. 调试分析
1.用一个数组来存储52张牌
2. 定义数组时由于每张牌要记录两个东西,就让每个数据包括两个数据项----纸牌号和记录纸牌正反面
五.测试结果
六. 附录(源代码)
#include<iostream>
#include<string>
】
using namespace std;
#define MAXSIZE 100um%i==0) isit==0) isit=1; else
[j].visit=0;
}
}
for(i=1;i<=52;i++) isit==0)
cout<<[i].num<<" ";。
}
cout<<endl;
}
void main()
{int i;
SqList L;
for(i=1;i<=52;i++)
{[i].num=i;
[i].visit=0;心得体会。