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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

C语言课程设计报告8000211.docx

1、C语言课程设计报告8000211单 位计算机与信息工程分院 分院(系)专 业 电气信息类(计) 学 号 学生姓名 指导教师 刘辉 完成日期 2009 年7月1日摘 要关键词:黑白棋,C语言,数组,分支,循环,图形处理,函数目录1.选题的意义 12系统功能需求分析 12.1 12.2 213系统设计 263.1 263.2 284系统实现 404.1 404.2 404总结 405.1总结 405.2 存在的主要问题 40参考文献 41 第1章 选题的意义题目名称:黑白棋游戏设计选题的目的:通过该题目的设计,使自己掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法和技能。分支、循环、

2、数组、函数等的综合运用;图形处理函数的使用。时间安排:6月24号7月1号主要参考文献: 1. C语言程序设计实例精粹. 谭明金 . 电子工业出版社2. C语言编程技巧及实用程序荟萃. 鲁沐浴. 电子工业出版社3. C语言课程设计案例精选与编程指导 陈清华. 东南大学出版社4. C语言课程设计案例精编. 郭翠英 . 中国水利水电出版社5. C语言实战105例. 王为青. 人民邮电出版社第2章 系统功能需求分析2、1 可行性分析科技的飞速发展,将人类带入了信息时代, 计算机越来越贴近人的生活,速度成为人们成功的前提条件,以致于人们必须不断尝试着使用各种手段来提高自身的工作效率,其手段之一就是对键盘

3、的充分利用和相应游戏软件的开发.智能型的游戏越来越深受广大游戏爱好者的喜欢.方便而快捷.黑白棋的游戏是要在一个8*8的网格中进行,而数组属于构造体类型,数组是具有相同数据类型的变量序列,序列中的每个变量成为元素,数组元素由一个统一标识的数组名和顺序好“下标”来表示。顾需要在游戏中定义一个二维数从而实现游戏的走棋、落棋、判断棋盘的变化等。游戏不同于基于C语言的其他程序(如学生成绩管理系统、教务工作管理系统、图书管理系统等)由于游戏本身的问地就在于缓解压力,所以基于C语言设计的游戏需要一个良好的游戏界面,给游戏者以轻松和愉快的感觉。TURBO C提供了70多个图形函数,这些函数包括在图形库文件gr

4、aphics.LIB中,他们被定义在graphics.h中。有如此强大的图形处理能力,去设计一个良好的人机交流界面是可行的。由于此游戏采用的是“人人对战”的模式,所以在游戏时,需要俩个游戏者轮流下棋,棋手1走棋完毕后,经过判断棋盘变化过程后棋手2走棋,游戏过程需要在俩棋手间不断进行转化。在C语言中,提供了包括ifelse,switchcase等分支语句,综合运用这些分支语句,可以完成上述转化。黑白棋游戏双方共需要走棋60手,每次走棋后,都需要根据相同的标准判断棋盘变化,来判断旗子颜色的变化情况。显然需要运用循环语句来简化编程的长度。C语言中提供了while for等循环语句可以实现上述功能。游

5、戏需要操作和输出显示游戏的结果,游戏的操作要由计算机的外部设备在人的操作下完成。C语言本身并不提供输入和输出语句,输入和输出的操作都是由函数来完成的,在C语言的标准库函数中提供了一些输入和输出的函数,这些函数的指针都是针对系统隐含指定的输入和输出设备的。综合运用这些输入和输出的函数可以实现上述的功能。经济可行性分析:本游戏的实现,花费了很多时间,但没有花费什么费用,而已这样简单但有一定难度的游戏更能激发游戏爱好者的兴趣,因此黑白棋游戏可以满足游戏市场的寻求.综合上述,基于C语言的游戏黑白棋的设计是可行的。2-2 游戏黑白棋的总体设想 在主函数中,通过调用绘制棋盘、棋手对战,判断棋盘变化、改变棋

6、子颜色等函数的调用来实现主函数的相应的功能 ,以下是有关于主函数的流程图。 绘制棋盘和初始棋子DrawQp棋手对战 play to play判断棋盘变化(能否分出胜负)QpChange计算棋手的成绩输出胜利者信息Y1DrawQp绘制棋盘和初始棋子在界面上绘制320*320的棋盘,并在棋盘中绘制8*8的格子,初始棋子2SetPlay设置棋子第一次的颜色先走棋者持白子,后走棋黑子,每次交替3Playtoplay人人对战函数俩棋手交替走棋,定义键盘操作等4MoveColor恢复原来棋盘状态棋子由初始位置到落子位置的路径不改变颜色5QpChange判断棋盘的变化改变棋子的颜色走棋后判断棋盘的变化情况,

7、根据变化情况判断是否可以输出分数6DoScore处理分数根据棋盘上旗子的多少进行分数的处理第三章、 系统设计3.1 系统界面设计(把设计界面复制到这里)3.2 系统编程设计本程序设计为人与人对弈,一方执黑棋,一方执白棋,轮流走。棋盘为88格,初始状态在棋盘中央交叉排放黑白棋子各两枚,为统计棋子个数,有一个棋子计一分,白棋先走。每个棋手下棋时,摆子的位置必须是以自己的棋子能包围住对方一个或多个棋子,被包围的对方棋子将变成自己的棋子。包围的方向可以是上下左右以及左右斜线共8个方向,只要能连成一条线即可。当轮到一个棋手摆子,而他没有可以包围对方棋子的位置时,他必须停步,让对方走棋,直到他可以走为止。

8、当棋盘上有一方的棋子为0或下满64格,游戏结束,棋子少者输。第四章、系统实现4.1系统编程代码#include #define LEFT 0x4b00#define RIGHT 0x4d00#define DOWN 0x5000#define UP 0x4800#define ESC 0x011b#define ENTER 0x1c0dint a88=0,key,scoreblack2=0,scorewhite2=0; qipan()/*开始画面*/int i,j; setbkcolor(BLUE); for(i=100;i=420;i+=40) line(100,i,420,i); line

9、(i,100,i,420); setcolor(0);/*取消圆周围的一圈东西*/ setfillstyle(SOLID_FILL,15); fillellipse(5); setfillstyle(SOLID_FILL,8); fillellipse(5); playcolor(int t)/*设置棋子第一次的颜色*/ if(t%2=0) setfillstyle(SOLID_FILL,15); else setfillstyle(SOLID_FILL,8); playcolortwo(int xx,int yy)/*走了一步后恢复原来那里的格子*/ if(yy100) setfillsty

10、le(SOLID_FILL,BLUE); else switch(a(xx-120)/40(yy-120)/40) case 1: setfillstyle(SOLID_FILL,15);break; case 2: setfillstyle(SOLID_FILL,8);break; default: setfillstyle(SOLID_FILL,BLUE); qipanchange(int xxx,int yyx,int t)/*棋盘的变化,也就是黑白的变化*/ int i,j,k,kk,ii,jj; i=(xxx-120)/40; j=(yyx-120)/40; playcolor(t)

11、; if(j6)/*开始判断变化*/ /*往右边*/ for(k=j+1;k8;k+) if(aik=aij|!aik) break; if(aik&k8) for(kk=j+1;kkk&k1)/*往左边*/ for(k=j-1;k=0;k-) if(aik=aij|!aik) break; if(aik&k=0) for(kk=j-1;kkk&k=0;kk-) aikk=aij; fillellipse(120+i*40,120+kk*); if(i6)/*往下*/ for(k=i+1;k8;k+) if(akj=aij|!akj) break; if(akj&k8) for(kk=i+1;

12、kkk&k1)/*往上*/ for(k=i-1;k=0;k-) if(akj=aij|!akj) break; if(akj&k=0) for(kk=i-1;kkk&k=0;kk-) akkj=aij; fillellipse(120+kk*40,120+j*); if(i1&j=0&kk=0&kkk&k=0;ii-,jj+) aiijj=aij; fillellipse(120+ii*40,120+jj*); if(i1)/*左下*/ for(k=i+1,kk=j-1;k=0;k+,kk-) if(akkk=aij|!akkk) break; if(akkk&k=0) for(ii=i+1,

13、jj=j-1;iik&k1&j1)/*左上*/ for(k=i-1,kk=j-1;k=0&kk=0;k-,kk-) if(akkk=aij|!akkk) break; if(akkk&k=0&kk=0) for(ii=i-1,jj=j-1;iik&k=0;ii-,jj-) aiijj=aij; fillellipse(120+ii*40,120+jj*); if(i6&j6)/* 右下*/ for(k=i+1,kk=j+1;kk8&kk8;k+,kk+) if(akkk=aij|!akkk) break; if(akkk&kk8&k8) for(ii=i+1,jj=j+1;iik&k8;ii+

14、,jj+) aiijj=aij; fillellipse(120+ii*40,120+jj*); doscore()/*处理分数*/int i,j;scorewhite0=scorewhite1=scoreblack0=scoreblack1=0;/*重新开始计分数*/ for(i=0;i8;i+) for(j=0;j8;j+) if(aij=1)/*分别统计两个人的分数*/ scorewhite1+; if(scorewhite1=10) scorewhite1=0;scorewhite0+; else if(aij=2) scoreblack1+; if(scoreblack1=10) s

15、coreblack1=0;scoreblack0+; printscore(playnum)/*输出成绩*/int i,j,k; int s2; if(playnum=1)/*把分数给这个临时变量*/ for(i=0;i2;i+) si=scorewhitei; else for(i=0;i2;i+) si=scoreblacki; if(playnum=1)/*清楚以前的成绩*/ setfillstyle(SOLID_FILL,BLUE); bar(400); if(playnum=1)/*判断输出的行数*/ k=200; else k=300; setcolor(RED); settext

16、style(0,0,4); for(i=0,j=550;iscorewhite0) outtextxy(black win!); else if(scoreblack0scorewhite1) outtextxy(black win!); else if(scoreblack1120)/*四个方向按键盘的判断*/ playcolortwo(xx,yy);/*判断原来位置因为画什么,这里只画蓝色是不完整的*/ fillellipse(xx,yy,15,15); playcolor(t); xx-=40; fillellipse(xx,yy,15,15); else if(key=RIGHT&xx

17、80) playcolortwo(xx,yy); fillellipse(xx,yy,15,15); playcolor(t); xx+=40; fillellipse(xx,yy,15,15); else if(key=UP&yy120) playcolortwo(xx,yy); fillellipse(xx,yy,15,15); playcolor(t); yy-=40; fillellipse(xx,yy,15,15); else if(key=DOWN&yy400) playcolortwo(xx,yy); fillellipse(xx,yy,15,15); playcolor(t);

18、 yy+=40; fillellipse(xx,yy,15,15); if(key=ESC) break; sum=0; for(i=0;i8;i+)/*判断是否棋子填满*/ for(j=0;j8;j+) if(aij!=0) sum+; if(sum=64) playwin();/*判断胜负*/ break; t+; if(t=11)/*如果t到了11就变成1*/ t=1; main()int gd=DETECT,gr; initgraph(&gd,&gr,c:tc); qipan();/*画棋盘*/ playtoplay();/*人人对战*/ getch(); closegraph();4.2 系统运行测试第五章总结5.1课程设计总结5.2 存在的主要问题及解决办法参考文献

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

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