C语言课程设计报告--黑白棋.doc_第1页
C语言课程设计报告--黑白棋.doc_第2页
C语言课程设计报告--黑白棋.doc_第3页
C语言课程设计报告--黑白棋.doc_第4页
免费预览已结束,剩余1页可下载查看

下载本文档

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

文档简介

c语言程序设计 课程设计题目: 黑白棋 课程设计(报告)任务及评语 学 号学生姓名专业班级程序设计(报告)题目黑白棋程序设计(报告)任务程序设计的任务与要求:(1)掌握c语言编程的基础知识。(2)较熟练地编写c语言应用程序。(3)了解c语言的常用标准函数、编程技巧、异常处理。(5)联系已学过的内容,巩固所学的理论,增强独立工作能力。(6)通过设计主要使学生有一个独立编写程序的过程,对理论学习及动手能力都有一个很大的提高。(7)通过本次设计,进一步培养学生热爱专业的思想,同时对本专业综合素质的提高起一个积极的推动作用。课程设计过程中,要严格遵守实践环节的时间安排,听从指导教师的指导。正确地完成上述内容,记录实习日记,规范完整地撰写出课程设计报告。指导教师评语及成绩成绩: 指导教师签字: 年 月 日目 录第1章 课程设计的目的与要求11.1 课程设计目的11.2 课程设计的实验环境11.3 课程设计的预备知识11.4 课程设计要求1第2章 课程设计内容22.1程序功能介绍22.2程序整体设计说明22.2.1设计思路22.2.2数据结构设计及用法说明32.2.3程序结构(流程图)42.2.4各模块的功能及程序说明62.2.5程序结果62.3程序源代码及注释6第3章 课程设计总结15参考资料 16第1章 课程设计的目的与要求1.1 课程设计目的本课程设计是计算机科学与技术专业重要的实践性环节之一,是在学生学习完程序设计语言(c)课程后进行的一次全面的综合练习。本课程设计的目的和任务: 1. 巩固和加深学生对c语言课程的基本知识的理解和掌握 2. 掌握c语言编程和程序调试的基本技能 3. 利用c语言进行基本的软件设计4. 掌握书写程序设计说明文档的能力5. 提高运用c语言解决实际问题的能力1.2 课程设计的实验环境硬件要求能运行windows 2000/xp操作系统的微机系统。c语言程序设计及相应的开发环境。1.3 课程设计的预备知识熟悉c语言及c语言开发工具。1.4 课程设计要求1. 分析课程设计题目的要求2. 写出详细设计说明3. 编写程序代码,调试程序使其能正确运行4. 设计完成的软件要便于操作和使用5. 设计完成后提交课程设计报告第2章 课程设计内容2.1程序功能介绍本游戏只有在可以吃到对方棋子的方格里落子吃子规则:采用夹吃的原则,左图用红色标记的是黑方可落子的位置。当黑方落子之后,则夹在两黑子中间的白子都将变为黑子。右图是落子后的棋盘布局,蓝色标记的是白方可落子的位置。夹子的方向包含:水平、竖直、斜对角。1点击“新游戏”,将从新初始化棋局。2 打开游戏存档,默认是.bwc文件3保存当前游戏,默认扩展名为.bwc4后退一步,即悔棋5前进一步,只有在前面的操作存在后退的基础上,该按钮才有效。6“与或图”按钮,当选择与或法与电脑博弈时会显示与或图。7点击设置按钮后,会出现以下对话框,可以修改设置,点击确定按钮后生效。2.2程序整体设计说明本程序设计为人与人对弈,一方执黑棋,一方执白棋,轮流走。棋盘为8乘8格,初始状态在棋盘中央交叉排放黑白棋子各两枚,为统计棋子个数,走一个棋子计一分,白棋先走。每个棋手下棋时,摆子的位置必须是以自己的棋子能包围住对方一个或多个棋子,被包围的对方棋子将变成自己的棋子。包围的方向可以是上下左右以及左右斜线共8个方向,只要能连成一条线即可。当轮到一个棋手摆子,而他没有可以包围对方棋子的位置时,他必须停步,让对方走棋,直到他可以走为止。当棋盘上有一方的棋子为0或下满64格,游戏结束,棋子少者输。2.2.1设计思路从程序表面看,这是一个二维平面图,所以数据用二维数组来表示,数组两个下标可以表示棋盘上的位置,数组元素的值代表棋格上的状态,共有三种情况,分别是0代表空格,1代表白棋,2代表黑棋。这样程序的主要工作是接收棋手按键操作,棋手用up、down、left、right控制光标移动,回车键表示落子。如果无棋可走则显示停步信息。一旦接收到回车键或空格键,说明棋手落子,先判断是否是有效位置,也就是说已经有棋子的位置不能重叠落子,然后再判断该位置能否吃掉对方的棋子(根据黑白棋的游戏规则,只能将棋子落子能吃掉对方棋子的位置上),如果条件满足则在该位置落子,落子时执行这样几个步骤,先调用画棋子函数,将棋盘的相应位置上画上棋子,再调用吃棋子函数,将对手的棋子变成自己颜色的棋子,然后根据吃掉对手棋子的个数,给自己加上相应的分数和给对手减去相应的分数,再将数组中的相应元素赋值,标志该位置已经落子,最后将落子的权限交给对手。2.2.2数据结构设计及用法说明 在主函数中,通过调用绘制棋盘、棋手对战,判断棋盘变化、改变棋子颜色等函数的调用来实现主函数的相应的功能。 绘制棋盘和初始棋子rawqp棋手对战 playtoplay判断棋盘变化(能否分出胜负)计算棋手的成绩输出胜利者信息y1绘制棋盘和初始棋子在界面上绘制320*320的棋盘,并在棋盘中绘制8*8的格子,初始棋子2设置棋子第一次的颜色先走棋者持白子,后走棋黑子,每次交替3人人对战函数俩棋手交替走棋,定义键盘操作等4恢复原来棋盘状态棋子由初始位置到落子位置的路径不改变颜色5判断棋盘的变化改变棋子的颜色走棋后判断棋盘的变化情况,根据变化情况判断是否可以输出分数6处理分数根据棋盘上旗子的多少进行分数的处理2.2.3程序结构(流程图)(1)落棋位置判断:(2)输出成绩:(3)输出最后的胜利者结果:2.2.4各模块的功能及程序说明落棋位置的判断模块:判断落子后棋盘的变化,判断棋手的落棋位置和次数,两方交换走棋。成绩输出模块:判断输出哪个棋手的分,在不同的位置输出,清空成绩,判断哪方胜利。输出胜利者信息模块:开始判断最后的结果,将两人分数分别输出。2.2.5程序结果一方执黑棋,一方执白棋,轮流走棋,每方都试图在游戏结束前让自己棋子的数目多于对方。按键盘上的方向键可以上下左右移动棋子,按回车键可以摆放棋子。下到最后谁的棋子多,谁赢。2.3程序源代码及注释size=12px#include graphics.h /*图形系统头文件*/ #define left 0x4b00 /*光标左键值*/ #define right 0x4d00 /*光标右键值*/ #define down 0x5000 /*光标下键值*/ #define up 0x4800 /*光标上键值*/ #define esc 0x011b /* esc键值*/ #define enter 0x1c0d /* 回车键值*/ int a88=0,key,score1,score2;/*具体分数以及按键与存放棋子的变量*/ char playone3,playtwo3;/*两个人的得分转换成字符串输出*/ void playtoplay(void);/*人人对战函数*/ void drawqp(void);/*画棋盘函数*/ void setplaycolor(int x);/*设置棋子第一次的颜色*/ void movecolor(int x,int y);/*恢复原来棋盘状态*/ int qpchange(int x,int y,int z);/*判断棋盘的变化*/ void doscore(void);/*处理分数*/ void printscore(int n);/*输出成绩*/void playwin(void);/*输出胜利者信息*/ /*主函数*/ void main(void) int00wq1 initgraph(&gd,&gr,c:tc); /*初始化图形系统*/ drap();/*画棋盘*/ playtoplay();/*人人对战*/ getch(); closegraph();/*关闭图形系统*/ void drawqp()/*画棋盘*/ int i,j; score1=score2=0;/*棋手一开始得分都为0*/ setbkcolor(blue); for(i=100;i=64-score1-score2) /*如果尝试超过空格数则停步*/ movecolor(x,y); fillellipse(x,y,15,15); break; else continue;/*如果按键无效*/ doscore();/*分数的改变*/ break;/*棋盘变化了,则轮对方走棋*/ else/*已经有棋子就继续按键*/ continue; else /*四个方向按键的判断*/ if(key=left&x120)/*左方向键*/ movecolor(x,y); fillellipse(x,y,15,15); setplaycolor(t); x-=40; fillellipse(x,y,15,15); else if(key=right&x80)/*右方向键*/ movecolor(x,y); fillellipse(x,y,15,15); setplaycolor(t); x+=40; fillellipse(x,y,15,15); else if(key=up&y120)/*上方向键*/ movecolor(x,y); fillellipse(x,y,15,15); setplaycolor(t); y-=40; fillellipse(x,y,15,15); else if(key=down&y400)/*下方向键*/ movecolor(x,y); fillellipse(x,y,15,15); setplaycolor(t); y+=40; fillellipse(x,y,15,15); if(key=esc)/*结束游戏*/ break; if(score1+score2)=64|score1=0|score2=0)/*格子已经占满或一方棋子为0判断胜负*/ playwin();/*输出最后结果*/ break; t=t%2+1; /*一方走后,改变棋子颜色即轮对方走*/ cc=0;/*计数值恢复为0*/ /*endwhile*/ void setplaycolor(int t)/*设置棋子颜色*/ if(t%2=1) setfillstyle(solid_fill,15);/*白色*/ else setfillstyle(solid_fill,8);/*灰色*/ void movecolor(int x,int y)/*走了一步后恢复原来格子的状态*/ if(y100)/*如果是从起点出发就恢复蓝色*/ setfillstyle(solid_fill,blue); else/*其他情况如果是1就恢复白色棋子,2恢复黑色棋子,或恢复蓝色棋盘*/ switch(a(x-120)/40(y-120)/40) case 1: setfillstyle(solid_fill,15);break; /*白色*/ case 2: setfillstyle(solid_fill,8);break; /*黑色*/ default: setfillstyle(solid_fill,blue);/*蓝色*/ int qpchange(int x,int y,int t)/*判断棋盘的变化*/ int i,j,k,kk,ii,jj,yes; yes=0; i=(x-120)/40; /*计算数组元素的行下标*/ j=(y-120)/40; /*计算数组元素的列下标*/ setplaycolor(t);/*设置棋子变化的颜色*/ /*开始往8个方向判断变化*/ if(j6)/*往右边*/ for(k=j+1;k8;k+) if(ak=aj|ak=0)/*遇到自己的棋子或空格结束*/ break; if(ak!=0&k8) for(kk=j+1;kk1)/*判断左边*/ for(k=j-1;k=0;k-) if(ak=aj|!ak) break; if(ak!=0&k=0) for(kk=j-1;kkk&k=0;kk-) akk=aj; fillellipse(120+i*40,120+kk*40,15,15); if(kk!=j-1) yes=1; if(i6)/*判断下边*/ for(k=i+1;k8;k+) if(akj=aj|!akj) break; if(akj!=0&k8) for(kk=i+1;kk1)/*判断上边*/ for(k=i-1;k=0;k-) if(akj=aj|!akj) break; if(akj!=0&k=0) for(kk=i-1;kkk&k=0;kk-) akkj=aj; fillellipse(120+kk*40,120+j*40,15,15); if(kk!=i-1) yes=1; if(i1&j=0&kk=0&kkk&k=0;ii-,jj+) aiijj=aj; fillellipse(120+ii*40,120+jj*40,15,15); if(ii!=i-1) yes=1; if(i1)/*左下*/ for(k=i+1,kk=j-1;k=0;k+,kk-) if(akkk=aj|!akkk) break; if(akkk!=0&k=0) for(ii=i+1,jj=j-1;ii1&j1)/*左上*/ for(k=i-1,kk=j-1;k=0&kk=0;k-,kk-) if(akkk=aj|!akkk) break; if(akkk!=0&k=0&kk=0) for(ii=i-1,jj=j-1;iik&k=0;ii-,jj-) aiijj=aj; fillellipse(120+ii*40,120+jj*40,15,15); if(ii!=i-1) yes=1; if(i6&j6)/* 右下*/ for(k=i+1,kk=j+1;kk8&kk8;k+,kk+) if(akkk=aj|!akkk) break; if(akkk!=0&kk8&k8) for(ii=i+1,jj=j+1;iik&kaiijj=aj; fillellipse(120+ii*40,120+jj*40,15,15); if(ii!=i+1) yes=1; return yes;/*返回是否改变过棋子颜色的标记*/ void doscore()/*处理分数*/ int i,j; score1=score2=0;/*重新开始计分数*/ for(i=0;i8;i+) for(j=0;jscore1)/*开始判断最后的结果*/ outtextxy(100,50,black win!); else if(score2outtextxy(100,50,white win!); else outtextxy(60,50,you all win!);第3章 课程设计总结通过本次c语言课程设计,我觉得对自己提高很大,克服了偷懒的毛病,这在我以后的学习和工作中的心理定位与调节有很大的帮助。我感受到了编程是一项非常繁琐周密的活动,它不但需要一个人周密思考问题的能力、处理问题的能力,还需要有足够的耐心和严谨治学的作风,来不得半点马虎。通过本次论文设计,我初步学会了论文设计的基本方法,学会了怎样去借鉴别人的方法和经验,知道如何去查找资料和整合处理这些资料的能力,这为以后的大学毕业设计论文打下了一个初步的基础使我受益最大的是享受到了一种成功的喜悦,在这两个星期之中从开始的确定论文题目,然后是上网和上图书馆查找资料,编写c语言原程序,然后是进行编译,这个环节是一个非常痛苦和艰难的,常常会因为一小点的错误而在编译失败与再次修改的漫漫循环之路中苦恼,但失败的越多,对人的考验就越多,在编译运行成功之后,享受成功的喜悦也就越多,另外在调试程序的过程中不断的思考和运用已经学到的知识,这对于自己是有很大的提高的。这个黑白棋游戏原程序的最大特点是采用了在主函数中调用子函数思想,每一种功能都是用子函数的办法来进行处理,简洁,清晰,方便,不容易出现错误。 在输入错误时本来想用一种警告的铃声来提醒用户,由于所学的知识不多,自己的编程经验不足,按现有的知识水平有些东西暂时还无法解决,还有待于在以后的学习中不断提高和改进!在课程设计过程中,我学到了很多人生的哲理,懂得怎么样去制定计划,怎么样去实现这个计划,并掌握了在执行过程中怎么样去克服心理上的不良情绪,黑夜过去了,我们收获的是黎明。在本次实践中,给我印象最为深刻的是在文件删除程序的编译过程

温馨提示

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

评论

0/150

提交评论