跳棋游戏C语言程序设计(数据结构课程设计).docVIP

跳棋游戏C语言程序设计(数据结构课程设计).doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
跳棋游戏C语言程序设计(数据结构课程设计)

跳棋程序设计 李雄志 学号:2012214157 数学与应用数学12-1班 问题描述; 程序分析; 程序算法; 思考感悟。 一,问题描述: 题目要求:设计一个跳棋程序,要求界面友好,可以实现人机对弈。 游戏规则: 玩家要先确定自己的棋子坐标 确定完坐标在确定将下的位置,但是只能下对角 当对角出现对方的棋子是则,可以将对方的棋子吃掉并且跳过棋子棋子不能向后走 如果双方其中一方到对方阵地3个就算赢,或者,双方其中一方棋子少于3个就算输。 在设计这个程序之前由于我做了前期准备工作主功能函数包含了整个游戏程序的函数,调用一个欢迎界面,然后打印棋盘,人机对弈的棋盘,然后人走棋,选择棋子(坐标),再选择即将落下地方的坐标,电脑走棋,如此往复,直至游戏结束?详细介绍:? 首先,先画好棋盘,把棋子全部放置好,对面是电脑,把玩家棋子是‘’,电脑的棋子‘’,其中空白是可走的,是不可走的,放置的方法可以是横列坐标之积整除2,即i×j%2==0,用cout来输出,并且把坐标画上,上面数字是列,右边数字是行画好棋盘后,接下来,考虑下棋的步骤,因为还要考虑吃棋子,所以先从走棋开始,开始玩家先走棋,玩家或者电脑选择了棋子后,会选择下棋的地方,电脑则是随机玩家则是选择下的坐标,然后是考虑吃棋子,电脑是遍历棋子,选哪些能否吃棋子,能则吃掉对方的棋子,并跳过去,玩家则是选择一个棋子,如果能吃棋子则吃。再有,在下棋的过程中,要用到清屏,头文件stdlib.h,其次,是不断的打印新的棋盘,这样才能观察玩家与电脑的对弈对应的函数成员re_disp()。其中遇到的问题,电脑走棋时,随机的棋子和随机下的地方,从右边看是遍历选择,吃棋子是,对角要有对方的棋子,而且对方后面没有棋子解决方案数组将坐标记录下来并且赋值。 三,程序算法: #includestdio.h #includeiostream.h #includeconio.h #includestdlib.h int t=1; int n=0;//表示真假 class TGame { public: TGame(); print(); computer(); re_disp();//重新显示棋盘 init_player(); game_judge();//判断胜负 eat_computer(); eat_player(int i, int j, int x, int y); private: char a[6][6]; int i,j; char swap;//交换 int win,fail; }; TGame::TGame() { win=0; fail=0; } TGame::print() { int s=0; cout 0 1 2 3 4 5endl; cout ┏-----┯-----┯-----┯-----┯-----┯-----┓endl;//打印棋盘格子 for (i=0;i6;i++) { for(j=0;j6;j++) { if((i+j)%2==0) { cout │ ; cout.;//此处不能走 a[i][j]=.; } else { cout │ ; if((i==3)||(i==2)) { cout ;//空白可以走 a[i][j]= ; } if(i=4) { coutA;//人的棋子 a[i][j]=A; } else if(i=1) { coutB;//电脑的棋子 a[i][j]=B; } } } cout │ s; s++; coutendl; if(s=5)//打印棋盘格子 { cout ┣-----┿-----┿-----┿-----┿-----┿-----┫; coutendl; } else { cout ┗-----┻-----┻-----┻-----┻-----┻-----┛; coutendl; } } } TGame::eat_player(int i, int j, int x, int y) { if(a[i][j]==A) if ((a[i-1][j-1]==X)||(a[i-1][j+1]==B)) { if((a[x][y]== )(i==x+2)(j=y+2)) { swap=a[x][y]; a[x][y]=a

文档评论(0)

yaobanwd + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档