课程设计掷骰子游戏设计.doc_第1页
课程设计掷骰子游戏设计.doc_第2页
课程设计掷骰子游戏设计.doc_第3页
课程设计掷骰子游戏设计.doc_第4页
课程设计掷骰子游戏设计.doc_第5页
已阅读5页,还剩11页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

C+课程设计华东交通大学基础学院C+课程设计报告题目:掷骰子游戏的分析与设计姓 名: 张 春 梅学 号: 20080810010101 班 级:08信息与计算科学(1)班学年学期: 2009 2010 学年 第 一 学期 日期:2009年12月21日目录一 掷骰子游戏设计需求分析21、掷骰子游戏需求22、游戏实现方式3二 类关系图和类主要成员函数和成员变量4三 模块的设计分析51、游戏类(class Player)的说明52、游戏类(class Player)的流程图83、程序运行结果:11四 存在的问题与不足及总结13五 掷骰子游戏使用说明书(操作手册)14一 掷骰子游戏设计需求分析1、掷骰子游戏需求:1)假如有n个学生排成一圈,编号从1到n,每个人有初始积分,不防设为100。2)从1号开始掷骰子,骰子出现后,根据点数减去掷骰人的相应积分, 如 减去 10*(6-点数),然后根据点数多少,就依次向后数掷骰的点数同等数量的人,被数到的最后一个人继续掷骰子,计算积分,依此类推。3)如果某人掷骰后,其积分小于等于0则出列,余下的人继续按照此法进行游戏,直到剩下最后一个人,为胜利者。4)要求打印每次出列的人的编号,掷骰子的次数,当前积分。并打印最后胜利者的相应信息。5)要求用环链表以及类来实现这个程序。6)选做:问掷骰m次后,还剩下几个人积分多少,显示出来。2、游戏实现方式:为了实现游戏的上述功能,在整个程序的设计中构造了一个游戏类(class player)。下面是游戏类(class player)的成员函数实现的功能:1)成员函数Player(char *pName,int id )用于储存参赛者的姓名和他们的编号;2)成员函数Player:Integral(int number)用于计算参赛者的当前积分和掷骰子的次数。3)成员函数Player:Initial( )用于创建参赛者的链表。4)成员函数Player:Game( )用于判断是否要有参赛者出列并记录当前参赛者的信息和掷骰子的次数、点数。5)成员函数Display( )用于打印本次游戏打印每次出列的人的编号,掷骰子的次数和最后胜利者的相应信息。二 类关系图和类主要成员函数和成员变量Player类code;countscorename20numOfPlayerPlayer * head;Player * next;Player ()Integral ()Display ()Player ()Initial ()Game ()code /每位参赛者的编号count /每位参赛者掷骰子的次数score /参赛者的积分name20 /参赛者的姓名numOfPlayer /参加游戏总人数三 模块的设计分析1.游戏类(class Player)的说明1).构造函数Player(char *pName,int id)用于储存参赛者的姓名和他们的编号;Player:Player(char *pName,int id) code=id; score=100; count=0; strcpy(name,pName); 先是从程序中输入参赛者人数,通过DOS屏幕的提示依次输入参赛者的姓名,系统会自动给参赛者编号,而这些信息由构造函数Player储存。2). Player:Integral(int number) 用于计算参赛者的当前积分和掷骰子的次数。Player:Player() Player *t;Player *p=head;for(int i=1;inext;delete t;int Player:Integral(int number) count=count+1;score-=(6-number)*10; if(score=0) return 0; else return 1; 通过构造函数 Integral ()来计算参赛者的当前积分和掷骰子的次数。另外该函数被后面的Game()函数调用,用于判断是否有参赛者出列。3).析构函数Player:Player() 。 因为分配了堆内存,所以当程序结束时要把空间给释放。4). Player:Initial()用于创建参赛者的链表。Player * ps;/创建的结点指针Player * pend;/链尾指针,用于在其后面插入结点Player:Initial() int id;int m; Player * ps; Player * pend; while(1)coutm;numOfPlayer=m;for(id=1;id=m;id+) cout请输入idpName; ps=new Player(pName,id); if(head=NULL) head=ps;else pend-next=ps; pend=ps; coutpNameendl已成功加入endlnext=head; ps=new Player(pName,id);/新建一个结点,准备插入链表5). Display( )用于打印本次游戏打印每次出列的人的编号,掷骰子的次数和最后胜利者的相应信息。6).Player:Game( )用于判断是否要有参赛者出列并记录当前参赛者的信息和掷骰子的次数、点数。srand( (unsigned)time( NULL ) ); do int numOfdice;/骰子数int q;static int k=0;k+;q=rand();numOfdice=q%6+1;/得到一个1-6的数在函数中求掷骰子的点数时用到了随机函数的模块,下面的文本框为骰子点数功能的实现。而函数中对链表的删除借鉴了书上的Josephus程序设计,另外删除链表条件的判断调用了上面的Player:Integral函数。2.游戏类(class Player)的流程图1)Player:Initial( )流程图如图1:2)析构函数Player:Player( )流程图如图2: 图1 图23)构造函数Player:Integral(int number)流程图如图3: 图34)Player:Display( )流程图如图4: 图45)Player:Game( )流程图如图5:6)main( )流程图容易图6: 图5 图6 3. 程序运行结果:输入参赛者人数如图7:图7输入参赛者姓名如图8:图8程序运行过程及最后结果如图9:图9四 存在的问题与不足及总结存在的问题与不足:1、进行游戏时,系统总是显示出“内存不能读”的对话框;2、选做的“问掷骰m次后,还剩下几个人积分多少,显示出来”没有成功,我当时做的时候出现了重新骰子数的情况,而不是打印出刚刚出现的掷骰m次后积分。总结:在本程序是我只创建了一个游戏类。各个功能的实现是通过调用类中的静态函数得已实现的。因为静态函数不仅可以不创建类对象也可以直接使用,并且可以访问类中的保护数据成员,所以基本的功能实现都是以类的静态函数来编写的。程序都是用链表的方式做的,因为链表比起数组可以节省不必要的内存空间分配,可以仅当需要是再分配新的空间。数组的空间分配是有限制的,而链表可以达到无限制的空间分配。五 掷骰子游戏使

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论