




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上福建农林大学计算机与信息学院课程设计报告课程名称:面向对象程序设计课程设计课程设计题目:五子棋姓 名:系:计算机专 业:软件工程年 级:学 号:指导教师:职 称:年 月 日福建农林大学计算机与信息学院计算机类课程设计报告结果评定评语:评分项目分值得分课程设计报告符合规范10分类图、用例图、系统框图合理30分主要技术线路正确30分设计报告条理清晰、重点突出20分有一定创新性、难易程度10分成绩:指导教师签字:任务下达日期:12 月6日评定日期:目 录.7.7 类的介绍.84.5 (5) 各个模块的介绍.84.6 (6)程序运行图示.145.总结.16参考文献.17(a)
2、 1.设计目的(1)加深我对面向对象程序基本的理解和掌握。(2)熟练掌握基本流程图的绘制。(3)熟练visio的一些操作方法。(4)能够在调试程序中快速发现并排除程序中的错误。(5)提高面向对象程序语言解决实际中的问题的能力。(b) 2.设计要求五子棋是玩家在游戏棋盘上逐个输入黑子或白子的坐标,因此游戏要求在DOS界面生成一个可供操作的棋盘。通过输入坐标完成对应落子情况,在输入过程中判断落子是否正确、是否有一方胜利等情况。编写代码可以在VC6.0下编译通过。游戏要能实现五子棋游戏的简单操作。程序中要体现面向对象思想。 (c) 3.设计方案(必须包含系统功能说明、用例图和类图)一、 用例图落子基
3、于用户的用例图步数用例图系统用例图1)输出棋盘界面菜单及图像2)开始进入控制3)黑白棋正确输入格式控制4)判断黑白输赢控制5)正确计数对羿步数及下一步所要走的棋盘界面 二、 类图(d) 4.设计内容本系统的主要结构和类结构1)五子棋功能实现的主要结构函数void getpointxy(); /白棋出子函数void getpointmn(); /黑棋出子函数void showqipan(); /实现20行20列正方形界面输出void print(); /输出下一棋盘界面及计数bool IsxyWin(); /白棋获胜bool IsmnWin(); /黑棋获胜void menu();/显示开始菜单
4、界面(2)五子棋类的结构class five int x,y,m,n,num_xy,num_mn; char qipan2020; /定义20行20列的数组public: five(int X = 0,int Y =0,int M = 0,int N = 0,int Num_xy = 0,int Num_mn = 0) /构造函数初始化x = X; y = Y; m = M; n = N; num_xy = Num_xy; num_mn = Num_mn; for(int i = 0 ; i < 20 ; i +) /输出20行20列的棋盘界面 for(int j = 0 ;j <
5、 20 ; j +) qipanij = '.' 系统工作流程介绍。 类的介绍:该类完成了对输入棋子坐标的初始化,通过for循环实现了一个20行20列的坐标,在公有成员中定义了相应的功能函数void getpointxy(); /白棋出子及计数void getpointmn(); /黑棋出子及计数void showqipan(); /实现20行20列正方形界面输出void print(); /输出下一棋盘界面bool IsxyWin(); /白棋获胜bool IsmnWin(); /黑棋获胜void menu();/显示开始菜单界面(5)各个模块的介绍:)类的实现:包括对数据成
6、员的赋值和成员函数的初始化还有通过for循环实现对20行20列坐标的定义:源代码如下class five int x,y,m,n,num_xy,num_mn; char qipan2020; /定义20行20列的数组public: five(int X = 0,int Y =0,int M = 0,int N = 0,int Num_xy = 0,int Num_mn = 0) /构造函数初始化x = X; y = Y; m = M; n = N; num_xy = Num_xy; num_mn = Num_mn; for(int i = 0 ; i < 20 ; i +) /输出20行
7、20列的棋盘界面 for(int j = 0 ;j < 20 ; j +) qipanij = '.' void getpointxy(); /白棋出子及计数void getpointmn(); /黑棋出子及计数void showqipan(); /实现20行20列正方形界面输出void print(); /输出下一棋盘界面bool IsxyWin(); /白棋获胜bool IsmnWin(); /黑棋获胜void menu();/显示开始菜单界面;)白棋和黑棋落子情况的判断的实现,源代码如下:void five:getpointxy() /判断白棋出子情况及对其计数 s
8、td:cout<<"请分别输入第"<<num_xy+1<<"步白棋的横坐标和纵坐标:" std:cin >> y >> x; if (!(1<=x&&x<=20&&1<=y&&y<=20) std:cout << "输入错误,请重新输入:"<<endl ; getpointxy(); else if(qipany-1x-1 != '.' ) std:cout <
9、;< "请所下的位置已经有棋子,请重新输入:" <<endl; getpointxy(); else if(num_xy+num_mn >= 400) std:cout << "棋盘已满,平局!" << endl; exit(0); else qipany-1x-1 = 'O' num_xy+; void five:getpointmn() /判断黑棋出子情况及对其计数 std:cout<<"请分别输入第"<<num_mn+1<<&qu
10、ot;步黑棋的横坐标和纵坐标:" std:cin >> n >> m; if (!(1<=m&&m<=20&&1<=n&&n<=20) std:cout << "输入错误,请重新输入:"<<endl ; getpointmn(); else if(qipann-1m-1!='.') std:cout << "请所下的位置已经有棋子,请重新输入:" <<endl; getpointmn()
11、; else if(num_xy+num_mn >= 400) std:cout << "棋盘已满,平局!" << endl; exit(0); else qipann-1m-1 = '*' num_mn+; 3)菜单界面模块void five:menu()/进入菜单界面char *q=new char9;cin>>q;if(strcmp(q,"c")five:showqipan();4)输出模块void five:showqipan() /输出20行20列的坐标数值 int p=0,q=0; f
12、or(int i = 0 ; i <= 20 ; i+) if(p<10) std:cout << p <<' ' else std:cout << p ; p+; cout << endl; for(i = 0 ; i < 20 ; i+) if(i>=0) q+; if(q<10) std:cout << q <<' ' else std:cout << q; for(int j = 0 ; j < 20 ; j +) std:cout &
13、lt;< qipanij<<' ' ; std:cout << endl; void five:print() int p=0,q=0; for(int i = 0 ; i <= 20 ; i+) if(p<10) std:cout << p <<' ' else std:cout << p ; p+; std:cout << endl; for(i = 0 ; i < 20 ; i+) if(i>=0) q+; if(q<10) std:cout <
14、;< q <<' ' else std:cout << q; for(int j = 0 ; j < 20 ; j +) std:cout << qipanij<<' ' ; std:cout << endl; 5)黑白棋输赢的判断,其源代码如下:bool five:IsxyWin()/白棋获胜实现函数 int num1=1,num2=1,num3=1,num4=1; for(int i = x ; i < x+5&& x+5<20 ; i +) if(qipan
15、y-1i != 'O') break; if(qipany-1i = 'O') num1+; for(i = x-2; i >= 0 ; i -) if(qipany-1i != 'O') break; if(qipany-1i = 'O') num1+; for( i = y ; i < y+5 ; i +) if(qipanix-1 != 'O') break; if(qipanix-1 = 'O') num2+; for(i = y-2; i >= 0 ; i -) if(q
16、ipanix-1 != 'O') break; if(qipanix-1 = 'O') num2+; for(i = 0 ; i < 5 && x+i<20 && y+i<20; i+ ) if(qipany+ix+i != 'O') break; if(qipany+ix+i ='O') num3+; for(i = 0 ; x - i -2>=0 && y-i-2>=0 && i < 5;i+ ) if(qipany-i-2x-
17、i-2 != 'O') break; if(qipany-i-2x-i-2 = 'O') num3+; for(i = 0 ; x + i < 20 && y - i - 2 >= 0 && i < 5;i +) if(qipany-i-2x+i != 'O') break; if(qipany-i-2x+i = 'O') num4+; for(i = 0 ; y + i < 20 && x - i - 2 >= 0 && i <
18、5;i +) if(qipany+ix-i-2 != 'O') break; if(qipany+ix-i-2 = 'O') num4+; if(num1>=5|num2>=5|num3>=5|num4>=5)return 1; else return 0; 黑棋获胜情况与白棋类似6)主函数模块void main() std:cout<<"*欢迎使用*_*"<<endl;std:cout<<"_"<<endl;std:cout<<"
19、;|"<<endl; std:cout<<"|"<<endl;std:cout<<"|"<<endl;std:cout<<"|"<<endl;std:cout<<"|"<<endl;std:cout<<"|"<<endl;std:cout<<"|"<<endl;std:cout<<"|&qu
20、ot;<<endl;std:cout<<"|"<<endl;std:cout<<"|"<<endl;std:cout<<"|"<<endl;std:cout<<"|"<<endl;std:cout<<"|"<<endl;std:cout<<"|"<<endl;std:cout<<"|"<
21、;<endl;std:cout<<"|"<<endl;std:cout<<"|"<<endl;std:cout<<"|-"<<endl;std:cout<<"进入按任意键"five a; /定义一个类的对象int temp; a.menu();std:cout << "这是本游戏的棋盘,请按坐标输入棋子:" << endl; a.showqipan(); /通过对象调用功能函数std
22、:cout << "确认请按1,退出请按其他键:" std:cin >> temp; if(temp !=1) /游戏开始及退出控制exit(1); if(temp = 1) std:cout << "游戏开始:" << endl; for(int i = 0 ; ; i +) a.getpointxy(); a.print();if(a.IsxyWin() std:cout << "白棋胜!" << endl; break; a.getpointmn(); a.
23、print();if(a.IsmnWin() std:cout << "黑棋胜!" << endl; break; std:cout << "游戏结束n" (6)程序运行图示:进入游戏界面棋盘界面通过输入横纵坐标完成落子下在同一个地方的情况获胜情况5.总结)通过此次课程设计,让我产生对益智游戏编程的兴趣,尤其是当我真正把那程序运行出来时,那种兴奋劲,无法比拟。)在这次课设的过程中当然也让我学到了很多东西,让我学到了很多课外的相关+高层次的东西,当然其中也复习到了+知识,尤其是通过类的运用,更让我体会面向对象在编程的过程
24、中的作用。3 )由于能力所限,所以该五子棋个相关功能还比较少,代码还过于冗长,我相信接下去只要我继续努力,一定可以克服次问题。参考文献1 廉师友编著,C+面向对象程序设计简明教程,西安电子科技大学出版社,19982 李师贤等编著,面向对象程序设计基础,高等教育出版社,19983 谭浩强编著,C+程序设计,清华大学出版社,2004附加源代码#include<iostream>using namespace std;class five int x,y,m,n,num_xy,num_mn; char qipan2020; /定义20行20列的数组public: five(int X =
25、 0,int Y =0,int M = 0,int N = 0,int Num_xy = 0,int Num_mn = 0) /构造函数初始化x = X; y = Y; m = M; n = N; num_xy = Num_xy; num_mn = Num_mn; for(int i = 0 ; i < 20 ; i +) /输出20行20列的棋盘界面 for(int j = 0 ;j < 20 ; j +) qipanij = '.' void getpointxy(); /白棋出子及计数void getpointmn(); /黑棋出子及计数void showqi
26、pan(); /实现20行20列正方形界面输出void print(); /输出下一棋盘界面bool IsxyWin(); /白棋获胜bool IsmnWin(); /黑棋获胜void menu();/显示开始菜单界面; void five:getpointxy() /判断白棋出子情况及对其计数 std:cout<<"请分别输入第"<<num_xy+1<<"步白棋的横坐标和纵坐标:" std:cin >> y >> x; if (!(1<=x&&x<=20&&
27、amp;1<=y&&y<=20) std:cout << "输入错误,请重新输入:"<<endl ; getpointxy(); else if(qipany-1x-1 != '.' ) std:cout << "请所下的位置已经有棋子,请重新输入:" <<endl; getpointxy(); else if(num_xy+num_mn >= 400) std:cout << "棋盘已满,平局!" << endl
28、; exit(0); else qipany-1x-1 = 'O' num_xy+; void five:getpointmn() /判断黑棋出子情况及对其计数 std:cout<<"请分别输入第"<<num_mn+1<<"步黑棋的横坐标和纵坐标:" std:cin >> n >> m; if (!(1<=m&&m<=20&&1<=n&&n<=20) std:cout << "输入错误,
29、请重新输入:"<<endl ; getpointmn(); else if(qipann-1m-1!='.') std:cout << "请所下的位置已经有棋子,请重新输入:" <<endl; getpointmn(); else if(num_xy+num_mn >= 400) std:cout << "棋盘已满,平局!" << endl; exit(0); else qipann-1m-1 = '*' num_mn+; void five:me
30、nu()/进入菜单界面char *q=new char9;cin>>q;if(strcmp(q,"c")five:showqipan();void five:showqipan() /输出20行20列的坐标数值 int p=0,q=0; for(int i = 0 ; i <= 20 ; i+) if(p<10) std:cout << p <<' ' else std:cout << p ; p+; cout << endl; for(i = 0 ; i < 20 ; i+) i
31、f(i>=0) q+; if(q<10) std:cout << q <<' ' else std:cout << q; for(int j = 0 ; j < 20 ; j +) std:cout << qipanij<<' ' ; std:cout << endl; void five:print() int p=0,q=0; for(int i = 0 ; i <= 20 ; i+) if(p<10) std:cout << p <<
32、;' ' else std:cout << p ; p+; std:cout << endl; for(i = 0 ; i < 20 ; i+) if(i>=0) q+; if(q<10) std:cout << q <<' ' else std:cout << q; for(int j = 0 ; j < 20 ; j +) std:cout << qipanij<<' ' ; std:cout << endl; bool f
33、ive:IsxyWin()/白棋获胜实现函数 int num1=1,num2=1,num3=1,num4=1; for(int i = x ; i < x+5&& x+5<20 ; i +) if(qipany-1i != 'O') break; if(qipany-1i = 'O') num1+; for(i = x-2; i >= 0 ; i -) if(qipany-1i != 'O') break; if(qipany-1i = 'O') num1+; for( i = y ; i <
34、; y+5 ; i +) if(qipanix-1 != 'O') break; if(qipanix-1 = 'O') num2+; for(i = y-2; i >= 0 ; i -) if(qipanix-1 != 'O') break; if(qipanix-1 = 'O') num2+; for(i = 0 ; i < 5 && x+i<20 && y+i<20; i+ ) if(qipany+ix+i != 'O') break; if(qipan
35、y+ix+i ='O') num3+; for(i = 0 ; x - i -2>=0 && y-i-2>=0 && i < 5;i+ ) if(qipany-i-2x-i-2 != 'O') break; if(qipany-i-2x-i-2 = 'O') num3+; for(i = 0 ; x + i < 20 && y - i - 2 >= 0 && i < 5;i +) if(qipany-i-2x+i != 'O') b
36、reak; if(qipany-i-2x+i = 'O') num4+; for(i = 0 ; y + i < 20 && x - i - 2 >= 0 && i < 5;i +) if(qipany+ix-i-2 != 'O') break; if(qipany+ix-i-2 = 'O') num4+; if(num1>=5|num2>=5|num3>=5|num4>=5) return 1; else return 0; bool five:IsmnWin() /黑棋
37、获胜实现函数 int num1=1,num2=1,num3=1,num4=1; for(int i = m ; i < m+5&& m+5<20 ; i +) if(qipann-1i != '*') break; if(qipann-1i = '*') num1+; for(i = m-2; i >= 0 ; i -) if(qipann-1i != '*') break; if(qipann-1i = '*') num1+; for( i = n ; i < n+5 ; i +) if(
38、qipanim-1 != '*') break; if(qipanim-1 = '*') num2+; for(i = n-2; i >= 0 ; i -) if(qipanim-1 != '*') break; if(qipanim-1 = '*') num2+; for(i = 0 ; i < 5 && m+i<20 && n+i<20; i+ ) if(qipann+im+i != '*') break; if(qipann+im+i ='*
39、39;) num3+; for(i = 0 ; m - i -2>=0 && n-i-2>=0 && i < 5;i+ ) if(qipann-i-2m-i-2 != '*') break; if(qipann-i-2m-i-2 = '*') num3+; for(i = 0 ; m + i < 20 && n - i - 2 >= 0 && i < 5;i +) if(qipann-i-2m+i != '*') break; if(qipann-
40、i-2m+i = '*') num4+; for(i = 0 ; n + i < 20 && m - i - 2 >= 0 && i < 5;i +) if(qipann+im-i-2 != '*') break; if(qipann+im-i-2 = '*') num4+; if(num1>=5|num2>=5|num3>=5|num4>=5) return 1; else return 0; void main() std:cout<<"*欢迎使用*_*"<<endl;std:cout<<"_"<<endl;std:c
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 嵌入式技术在医疗行业的应用试题及答案
- 数据库管理中的挑战与机遇试题及答案
- 稀有稀土金属加工前沿技术探讨考核试卷
- 风险控制在嵌入式项目中的应用试题及答案
- 嵌入式产品交付策略试题及答案
- 公路管理体系与规范试题及答案
- 全面修订安全管理制度
- 工地排水配件管理制度
- 实战模拟计算机三级数据库试题及答案
- 公司保温车间管理制度
- 正畸治疗中的口腔健康教育和卫生保健课件
- 簧片落料弯曲级进模设计毕业设计(论文)
- 完整版8D改善报告
- MSA测量系统分析软件(第三版A级实例)
- 工业硅技术安全操作规程
- 精密压力表计量标准技术报告(共16页)
- 消防工程项目样板区、样板间方案
- 导流明渠施工方案(共4页)
- 小学美术三年级下册第5课我们班级的标志PPT课件
- 儿童社会工作案例及分析PPT学习教案
- 均相液体机械搅拌夹套冷却反应器设计
评论
0/150
提交评论