ImageVerifierCode 换一换
格式:DOCX , 页数:14 ,大小:240.57KB ,
资源ID:9362504      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/9362504.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(+c+程序设计 扑克牌游戏大学毕设论文.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

+c+程序设计 扑克牌游戏大学毕设论文.docx

1、+c+程序设计 扑克牌游戏大学毕设论文 齐鲁理工学院VC课程设计报告 课 程:VC+课程设计 系 别:计算机科学与信息工程学院班 级: 学 号: 选题2名称:扑克牌游戏选题2难易级别: 起止时间: 指导教师: 扑克牌游戏一 课题目标 1.1 程序功能介绍 创建一副扑克,并完成洗牌等操作。1.2 程序设计要求(1) 创建一副扑克,显示一副扑克,洗牌,依次分发给4个人并显示。(2) 删去一张扑克后,余牌显示。 (3)增加大小王1.3 评定难易级别:A级二 具体实现2.1 程序总体方案 2.1.1开发平台 操作系统:Windows 7 开发工具:VC+6.02.2 源程序结构流程框图与说明(含新增子

2、函数的结构框图以及界面)洗牌依次分发给4个人并显示删去一张扑克后,余牌显示YN2.3课程设计的解答说明创建一副扑克,并完成洗牌、发牌、显示、花色排序、面值排序、删除一张牌、删除一轮牌等操作。本程序新建了PerDeck和PlayDeck两个类,类PerDeck表示某个人拿的牌,类PlayDeck表示四个人玩牌的过程,对原程序的修改较小。程序中用到了包含在头文件stdlib.h中的函数srand(),用来初始化随机数种子,以使每次执行程序时函数rand()产生不同的随机数,从而使程序每次产生不同的运行结果,用到了包含在头文件time.h中的函数time(),用到了包含在头文件conio.h中的函数

3、getch()用来接收用户从键盘键入的任意键,以起到暂停程序供用户查看运行结果的作用,还用到了包含在头文件stdlib.h中的函数system(),其参数为字符串,字符串cls代表清屏操作。1 课程设计的任务分解为了完成要求(1)增加大小王,须将类Deck中的成员数据m_cardarray由52增加到54,用来创建一副包含大小王在内54张牌的扑克,并在创建扑克时为大小王重新赋值,如果num=52,则这张牌为小王并将这张牌的花色赋为1,面值赋为S,实际面值赋为14。如果num=53,则这张牌为大王并将这张牌的花色赋为2,面值赋为B,实际面值赋为15。为了完成要求(2)删去一张牌后显示余牌,需先定

4、义int DeleteAll(int,int,int,int)、int DeleteOne(int,int)、int Delete(int)和void PerDeck:Show()、void PlayDeck:Show()函数,并在程序执行期间调用int DeleteAll(int,int,int,int)、int DeleteOne(int,int)、int Delete(int)函数后调用void PerDeck:Show()、void PlayDeck:Show()函数。为了完成要求(3)显示一副扑克,需在原来的基础上把函数ShowDeck()改成显示54张牌,洗牌函数也应改成对54张牌

5、进行洗牌,用函数void PlayCard(Deck & )来给玩家发牌,并调用函数void PerDeck:Show()、void PlayDeck:Show()显示玩家牌面。2 课程设计的新增函数void PerDeck:MakeperDeck(Deck & ,int)函数用来给每个玩家发牌,给第一个玩家和第二个玩家发14张牌,第三和第四个玩家发13张牌,其整型参数是发给玩家牌的张数,另一个引用参数是洗好的那副牌的对象,用来给玩家发牌。void PerDeck:Show()/函数用来显示当前玩家手中的牌。int PerDeck:Delete(int)/函数用来删除一张牌void PerDe

6、ck:SortFace()/函数用来把玩家手中的牌进行面值排序void PerDeck:SortSuit()/函数用来把玩家手中的牌进行花色排序PerDeck:PerDeck()/类PerDeck的构造函数void PlayDeck:PlayCard(Deck & )/函数用来调用函数 MakeperDeck(Deck & ,int)/给玩家发牌,参数为洗好的那副牌的对象的引用。void PlayDeck:Show()/用来显示四个玩家手中的牌。int PlayDeck:DeleteAll(int,int,int,int)/用来删除一轮牌,参数分别为四个玩家的第几张牌。int PlayDeck

7、:DeleteOne(int,int)/用来删除一张牌,参数分别为第几个玩家的第几张牌。void PlayDeck:SortDeckFace()/完成对四个玩家手中的牌按面值排序。void PlayDeck:SortDeckSuit()/完成对四个玩家手中的牌按花色排序。PlayDeck:PlayDeck()/类PlayDeck的构造函数三 调试报告3.1调试时界面显示情况(1)显示完整的一副牌(2)洗牌后分发给四个玩家并显示(3)选择功能1时(4)选择功能2时 (5)选择功能3时 (6)选择功能4时 (7)选择功能5时 3.2调试报告:日期遇到的问题解决方法9月25日程序所需数据及函数较多,

8、比较混乱多增添两个类PerDeck和PlayDeck10月05日添加大小王时,产生整副牌时大小王的产生位置。需要首先生成大小王,再产生其他牌,不然会产生多一张A 和210月08日发给四个人时分牌困难。通过this指针来处理10月10号对书上的代码中的产生随机数及计算机洗牌不理解上网查找类似的代码看注解以及问同学10月15日函数的界面太单调,不知道怎样创建程序主菜单使用Program_Init();Center_Text(char );Get_Key()等函数实现10月18日对程序中的扑克牌的花色、面值赋值有点不理解看书上的知识及问同学四 总体小结 问题1:如何洗牌。解决方法:创建洗牌函数voi

9、d Deck:DeckShuff( int times) /洗牌,参数为洗牌次数。其中包括随机的实现,运用生成随机数的方法:包含了头文件stdlib.h、time.h。 srand(unsigned)time(NULL); /time.h。每个伪随机数都是通过在内部定义的一个特殊“数字压碎函数”由上一个伪随机数生成的,第一个伪随机数是由一个内部定义的变量生成的,该变量称为这个序列的种子。在默认情况下,在程序每次运行时种子由计算机初始化为同一个值(默认为1),为了避免这种破坏随机性的现象,可以用srand( )函数来选择自己的种子。代码srand(seed)将定量seed的值赋给内部的“种子”,

10、函数rand( )使用该种子来初始化所产生的伪随机数序列,不同的种子会生成不同的结果。必须输入一个 seed的值的问题,可以使用计算机的系统时钟来解决,系统时钟以秒为单位跟踪当前的时间。在头文件中定义的函数time()以一个unsigned整数返回当前时间,可以作为rand( )函数的种子。这样就能保证每次都能生成不同的随机数了。 int getRandInt(int min, int max) /返回两个参数之间的一个整型随机值 int numToReturn; numToReturn = rand(); /取得随机值 numToReturn = numToReturn % (max - m

11、in + 1) + min; /*将随机值的范围调 整到两个参数之间*/ return numToReturn;利用计算机的系统时钟做种子只能解决每次生成不同的随机数的问题,而作为扑克牌,每次生成的随机数应该是有一个严格的范围的。所以设计了getRandInt函数来解决这个问题,代码如上。但要完成洗牌不仅仅如此,洗牌需要将牌大致(随机函数)一分为二,然后交叉洗牌,重复N次。代码如下:void Deck:DeckShuff( int times) /洗牌,参数为洗牌次数 int x, split; /split是分开成两部分的位置,如上部分、下部分,即随机给两方分别发一副牌 Center_Tex

12、t(洗牌); cout endl; for(x=0;x=times;x+) /开始循环,每循环一次将牌全部重排一遍 split = getRandInt(20,35); /生成介于 20 和 35 之间的随机数,赋值给 split, Deck topdeck; / 1副扑克牌类的对象 topdeck,代表上部分的牌 Deck bottomdeck; / 1副扑克牌类的对象 bottomdeck,代表下部分的牌 int i; int bottomdeckindex = 1; / 记录上部分发了多少张牌 int topdeckindex = 1; / 记录下部分发了多少张牌 for(i=0;im_

13、cardarrayi; topdeckindex+; i+; for(i=(split);im_cardarrayi; bottomdeckindex+; i+; int deckoutindex = 0; int numcardstomovetop; int numcardstomovebottom; int j; int h = 0; bottomdeckindex = 54 - split; /下部分那副扑克牌的张数 topdeckindex =split; /上部分那副扑克牌的张数 while(deckoutindex = 53) numcardstomovetop = getRand

14、Int(2,7); /从上部分抽取的张数,是2-7之间的随机数 numcardstomovebottom = getRandInt(2,7); /同样从下部分抽取的张数,是2-7之间的随机数 for(j=0;j 0) /当下部分那副牌没有循环完时继续 this-m_cardarraydeckoutindex = bottomdeck.m_cardarraybottomdeckindex; /*从下部分那副牌的最后张数开始,依次向初始的扑克牌赋值*/ deckoutindex+; bottomdeckindex-; for(h=0;h 0) & (deckoutindex m_cardarray

15、deckoutindex=topdeck.m_cardarraytopdeckindex; deckoutindex+; topdeckindex-; this-m_lastdelt = -1; /将删除牌的张数复原为-1(未删除)问题2:如何实现花色排序和面值的排序。解决方法:可以使用冒泡排序法和选择排序法。代码如下:void PerDeck:SortFace() /按面值排序,使用了选择排序法 Playing_Card record; /产生一个临时对象 for(int j=0;jnNum-1;j+) for(int i=j+1;im_Cardi.m_Value) record=m_Car

16、di;m_Cardi=m_Cardj;m_Cardj=record; void PerDeck:SortSuit() /按花色排序,使用了冒泡排序法 Playing_Card record; /产生一个临时对象 for(int i=0;inNum-1;i+) for(int j=0;jm_Cardj+1.m_Suit) record=m_Cardj;m_Cardj=m_Cardj+1;m_Cardj+1=record;心得体会: 开始进行设计时,总觉得无从下手,感觉这是一个不可能完成的任务。后来在同学的建议下,将这学期C+所学的c+知识仔细的看了几遍,再开始看C+课程设计书。鉴于对抗游戏和扑克

17、牌游戏接近生活,对它们的设计要求理解比较透彻,所以选择了它们。首先,先发了五天的时间看设计要求和源代码,然后才进行编写,经过对所编程序的不断调试和改写以及与他人编写的进行对比,最后终于使程序能正常运行了。为了更好的进行更改,我把所编的程序打印下来,仔细的查看每个函数,用笔进行修改,然后再到程序上修改调试。当然,在整个实验过程中,不断遇到各种问题,在同学的帮助下和自己的努力下,不断的解决问题,一次次的不断尝试,不断调节,使解决问题的能力有了提高。并对程序的编写有了一定的了解,对将来的学习方向有了进一步的认识。总之,课程设计可以充分发挥我的编程综合能力,将自己的编程知识串联起来,综合利用,自己的编程能力。很高兴有这个机会促使我编程。总之,在这个程序设计中的收获还是非常多的。五 分工介绍 独立完成

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1