




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、c语言课程设计(小游戏贪吃蛇的程序设计报告)设计人:班级:2。1年月号目 录一:概述1:研究背景及意义2:设计的任务与需要知识点3:具体完成设计内容二:需求分析1:功能需求2:操作方法三:总体设计1:模块划分2:数据结构设计四:详细设计1:主空摸块设计2:绘制游戏界面3:游戏的具体过程4:游戏的结束处理5:显示排行榜信息模块五:程序的调试与测试1:动画与音乐同步2:蛇的运行3:终止程序六:结论七:结束语八:程序清单九:参考文献概述本课程设计以软件工程方法为指导,采用了结构化,模块化的程序设计方法,以c语言技术为基础,使用 turbo c+3.0为主要开发工具,对贪吃蛇游戏进行了需求分析,总体
2、设计,详细设计,最终完成系统的实现与测试。1.1 研究的背景及意义随着社会的发展,人们生活的节奏日益加快,越来越多的人加入了全球化的世界。人们不再 拘泥与一小块天地,加班,出差成了现代人不可避免的公务。而此时一款可以随时随地娱乐的游戏 成为了人们的需要。此次课程设计完成的贪吃蛇小游戏,正是为了满足上述需求而设计出来的。贪吃蛇游戏虽小,却设计诸多的知识点。通过开发贪吃蛇游戏系统,可使读者初步了解使用软件工程的和那个发,技术和工具开发软件的过程,进一步掌握结构化,模块化 的程序设计方法和步骤,进一步掌握总体数据结构设计,模块划分方法,掌握局部变量,全局变 量,结构体,共用体,数组,指针,文件等数据
3、结构的使用方法,掌握图形,声音,随机数等多种库函数的使用方法,学习动画,音乐,窗口,菜单,键盘等多项编程技术,进一步学会软件调试,测试,组装等软件测试方法,为后续课程的学习和将来实际软件开发打 下坚实的基础。1.2 设计的任务和需要的知识点1.2.1 课程设计主要完成的任务1) .通过编写“贪吃蛇游戏”程序,掌握结构化,模块块化程序设计的思想,培养解决实际 问题的能力。2)有同步播放动画,声音效果。3)设计好数组元素与蛇,食物的对应关系。4)随机产生食物。5)有分数统计,排行榜,分数存储等功能。通过此次课程设计,希望使读者能更深入的理解和掌握课程教学中的基本概念,培养读者应用基本技术解决实际问
4、题的能力,从而进一步提高分析问题和解决问题的能力。1.2.2 需要掌握和运用的知识点1.2.3 本次课程设计需要掌握和运用如下的知识点:1)数组的应用。2)全局变量的使用。3)按键处理。4)结构体的应用。5)图形,音乐和动画的有关知识。6)随即函数的使用。7)文件的基本出操作。8)结构化,模块化的设计方法。1.3 具体完成的设计内容在本次课程设计中需要完成的任务有:包含命令,全局变量的定义和宏定义,函数声明 等(50行),主控模块(main函数,14行),动画,音乐播放模块(drawsnow函数,33行),画出游戏开始界面模块,具体游戏过程模块,游戏结束处理模块。开发中工作量 约为215行源代
5、码。二.需求分析贪吃蛇游戏是个简单的小游戏,能让游戏者的身心得到娱乐,从而能够更好地投入到学习或工作当中。虽然现在市面上出来这各种各样的游戏版本,可是贪吃蛇这类的小游戏其市场 还是相当大的,因为它玩法简单易行,不论是手机,还是小游戏机,都能很顺利的运行。对于在外忙碌的人,不可能花费大量时间在娱乐上,大型游戏是行不通的,这样的小游戏刚好迎 合了他们的需求。2.1 功能的需求要开发贪吃蛇游戏程序,首先要分析改程序应实现哪些功能。对贪吃蛇游戏程序的功能需 求可描述如下:程序运行后显示动画,音乐,按esc键退出游戏界面后,左边有一个矩形区,外游戏区域, 在矩形区中有食物和贪食蛇,上方有统计分数及关数显
6、示区域。蛇在封闭围墙利用绿色矩形表示,围墙里随机的出现一个食物,通过按键盘四个光标键控制 蛇向上,下,左右四个方向移动,蛇头撞到食物,则食物被吃掉,蛇身体长一节,接着又出现食物,等待蛇来吃。食物用一个点表示,并且每次食物的位置都是随机出现的。游戏中要使 贪吃蛇尽可能的长,但是不能使贪吃蛇撞到四周的墙壁,而且蛇的身体不能撞到一起,否则游戏结 束。游戏中每吃掉一个食物要有积分,随着分数的增加可进入下一关,即使速度会加快。游戏结束时,如果分数进入前5名则重新排榜并存储。显示排行榜。由于有关贪吃蛇和食物的数据较多,而且关系密切,贪吃蛇及食物都是定义结构体数据类型,这样定义便于操 作与处理。2.2 操作
7、方法2.2.1. 进入游戏2.2.2. 游戏界面2.2.3. 游戏操作2.2.4. 游戏结束三总体设计确定贪吃蛇游戏体系结构,给出总体模块结构图,确定程序的主要函数及之间的调用关系, 同时设计蛇与游戏者等的数据结构。3.1 模块划分本程序采用结构化程序设计的方法,按照自顶向下,逐步细化的方法对要解决的问题进行逐层分解。首先画出顶层模块,即主控模块,之完成对下层模块的调用功能,即调用其他的功能模块;接着,按需求分析中的功能需求设计第一层模块,有音乐动画,图形驱动,画主界面,游戏过程,结束处理,退出等第6个主要功能;接着,画出第二层模块。总体模块结构如图6-1所示。3.1.1. 主控模块。3.1.
8、2. 动画音乐模块3.1.3. 画主界面模块3.1.4. 游戏过程模块3.1.5. 游戏结束处理模块3.1.6. 读取记录模块3.1.7. 成绩排序模块3.1.8. 写入文件模块3.1.9. 排行榜模块3.1.10. 退出3.2 总体数据结构设计设计思路:测序的关键在于表示蛇的图形及蛇的移动。用一个小局限性方块表示蛇的一节身体,身体每长一节,增加一个矩形块,蛇头业用同样的一节小矩形方块表示移动时必须 从蛇可以上向前爬行,档案下有效方向键后,应先确定蛇头的位置,而后蛇的身体虽蛇头移 动,图形的实现是从身体新位置开始画出蛇。这时,由于未清屏的原因,原来的蛇的位置和新蛇的位置差一节蛇身,即看起来蛇多
9、一节身体,所以将蛇的最后一节用背景色覆盖。食物的出现与消失意识画矩形块和覆盖矩形块。为了便于理解,定义两个结构体:食物与蛇。下 面介绍贪吃蛇游戏程序的主要数据结构。3.2.1. 食物与蛇的数据结构表示食物与蛇的矩形块设计为10*10个像素单位,食物的基本数据域为它所出现的位置,用x和y坐标表示,则矩形块用函数rectangle ( x,y,x+10 , y+10 )或rectangle(x,y,x+10 , y-10)可以画出。由于每次只出现一个食物,所以设定 yes表示是否需要出现食物。yes = 1表示没有食物或食物已经被蛇吃掉,需要画出食物。放置食物后,置yes二o。蛇的一节身体为一个矩
10、形块,表示矩形块只需左上角点坐标( x,y) o由于在游戏过程中蛇 的身体不断增长,需用数组存放每节坐标,最大设定为n=200 , node表示当前节数。direction是保存蛇的移动方向的变量,其值可为1、2、3、4之一,分别表示右、左、上、下的方向。life是表示生命的变量,life=0 表示蛇活着,一旦 life=1 , 一旦life=1 , 表示蛇死,结束游戏。#detine n 200struct food int x;int y;int yes;food;structsnake int xn;intyn;int node;intde rection;int life;jsnake
11、;3.2.2. 排行榜中优胜者的数据结构排行榜主要记录优胜者的姓名和成绩。为了存放排行榜信息,可定义如下的结构体类型,其 中字符数组name成员存放优胜者的姓名,整型变量score成员存放优胜者的成绩。struct personchar name20;int score;3.2.3. 其他全局变量的定义struct person per5;int score =0;int gamespeed=400;3.2.4. 符号常量的宏定义#define#define#defineleftrightdown0x4b00;0x4d00;0x5000;#defineup0x4800#detineesc0x0
12、1 lb#define filename四.详细设计根据总体设计的模块功能和结构,完成所承担的程序模块的算法设计。给出每个模块的详细 的算法,算法分别用传统流程图和文字说明来描述。4.1 主控模块main函数主函数是程序的主控模块。首先初始化图形系统,然后使用drawsnow函数播放动画和声音,接着调用init函数初始化图形系统,之后调用drawk函数画出游戏开始画面,在调用gameplay函数,即开始了游戏的具体过程, 游戏结束后调用endplay函数进行游戏结束处理; 从文件中读取记录信息,排序,显示排行榜信息,最后关闭图形系统,结束程序。主控模块 的流程图如图6-2所示。其中带有两个竖线
13、的矩形框表示对自定义函数的调用。4.2 绘制游戏开始界面drawk函数绘制游戏界面的函数的算法流程图如图 6-3所示。主界面就是一个封闭的围墙,用两个循环语句分别在水平方向和垂直方向输出连续的宽度和高的均为10个像素单位的距行小方块,围成封闭图形表示围墙,为了醒目,设置为淡青色,用函数setlinestyle设直线型宽度为 3个像素,设置3个像素的围墙线,。最后,在界score )和关(level)的表头。面的左上部输出游戏程序的版本信息,在右上部输出游戏成绩(4.3 游戏具体过程gameplay函数该函数是游戏的核心部分。游戏具体过程 gameplay函数的大致算法流程图如图 6-4所不o下
14、面对该算法不够详细的地方作进一步的描述。确定蛇头位置窗蛇身,蛇死4.3.1为防止食物总是出现在一个位置上,要设置随机数发生器的种子数,产生真正的随机数。由于还没有画出食物,并设置需要食物,并设置蛇活着。初始时,蛇只有蛇头和1节蛇尾,设置这2节坐标。设定蛇开始的爬行方向左右。4.3.2 随机确定食物位置由于蛇吃到食物的判断是蛇头的坐标和食物的坐标相等,所以要确保食物出现的位置x、y坐标,然后在10的倍数位置上。先用两个带随机函数的表达式产生一个位于围墙内的用两个while循环将两个坐标值调整到10的倍数上,这样就可以让蛇吃到。4.3.3 循环确定蛇身的新坐标这里的难点是表示蛇的新位置并消除前一次
15、的图形。采用的方法是每次移动的时候从最后一节 开始到第二节,将前一节的坐标值赋给后一节的坐标,移动后只要把最后一节用背景色擦出即可, 因为新位置。到n-1节还是要出现在画面上的。这里用一个for循环来确定蛇身的新坐标。4.3.4 吃到食物后的处理蛇吃到食物后,首先将食物擦除,即用背景色画出该食物,然后给蛇的节数加匕设置需要食物标志,是游戏成绩加1。分,如果成绩达到50分的倍数,则给关数加戏速 1,并加快游 度。4.3.5 有按键判断蛇的方向这是一个内嵌的嵌套的条件选择结构,根据安东上下左右键来设定蛇的移动方向。其中1 =向 右,2=向左,3=向上,4=向下。判断是还考虑相反的方向键无效,比如蛇
16、正在向上爬 行,按下一键方向是无效的。4.4 游戏的结束处理木块endplay函数游戏结束时,应该用endplay函数进行游戏结束处理,其算法流程图如图6-5所示显示排行榜该块首先调用读取排行榜文件的记录,如果文件不2存在,则在 readfiles函数中调用initscorefiles函数建立该文件,然后再读出记录。其次,判断游戏者的成绩是否可以上排行榜。如果可以上榜,则画出淡蓝色矩形界面, 在界面中输入游戏者姓名,对成绩进行赋值,然后调用comparescore函数对记录排序,并调用 write tiles函数将记录写入排行榜帮文件;如果不能上榜,则直接在游戏界面输出不能上榜信息。最后,调用
17、pain_board函数显示排行榜信息。4.5函数void pain_board完成排行榜的绘制五.程序的调试与测试调试与测试软件的目标就是发现并改正潜伏的错误。一个程序,必须经过认真的调试和测试,才能尽量减少错误、保证程序满足功能、性能需求,达到最初的设计、使用要求,从 而保证程序的开发质量。详细设计完成后,就可以用c语言根据各个模块的算法来设计程序,每个模块都要设计成一个自定义函数。 几个模块可以放在一起构成一个原函数程序文件,也可以一个模块构成一个源程序文件。 原程序设计好后,输入到计算机中,并存储到磁盘上; 然后对每个源程序文件都进行了独立编译和调试(具体代码可以参看程序清单);并针对
18、不同的模块程序设计测试用例进行单元测试;最后,将几个分别开发的模块组装在一起,形成一个完整的程序,进行集成测试,从而发现并改正了程序程序中存在的一些潜藏的错误,并使程序的容错能力大大增强。5.1 动画与音乐的同步播放预期结果:片头在显示动画得同时播放音乐;按任意键后进入游戏主界面;进入游戏主界面后动画音乐同时停止。实际运行效果:满足和,不满足 ,即进入游戏后仍然播放片头音乐。错误分析:程序中使用循环播放动画,并在其循环体中插入发声函数以达到音乐和动画的同步。由于在结束动画时没有关闭扬声器,所以进入游戏界面后仍然发声。修改:在动画播放完后加一条“ nosound ();”语句将扬声器关闭,问题得
19、到解决。修改后 程序运 行的实 际效果 与预期 效果一5.2 蛇的运行5.2.1 蛇撞到墙预期结果:蛇运行时如果撞到墙壁,则游戏结束。6-9所示。实际运效果:超出左右墙壁后程序结束,但超出上面墙壁后仍然运行,如图错误分析:错误程序段在蛇运行中的条件判断语句中,其判断条件是:if (snake.x0595 ),即少了上、下两个方向的判断。修改:在蛇的运行过程中添加两个逻辑表达式,判断蛇是否闯到上下的围墙。代码:if ( snake.x0595ll snake.y0455 )修改后的程序运行结果与预期的结果5.2.2 蛇头闯到蛇身预期的结果:当蛇得头部与蛇身相撞时,游戏应当结束。实际运行效果:蛇头
20、撞到蛇身时,程序并不终止。错误分析:在蛇的运行判断的程序出错,其代码如下fori=3 ;is nake .node ;i+)if(snake.xi=snake.x0&snake.yi=snake.y0)snake .life =o;bre a k;)修改:将循环体中的snake.li佗=0改为snake.li佗=1 ;修改后的结果与预期结果一致。5.3 终止循环经过对各个模块的调试和单元测试并修改了错误后,将各个模块组装成一个系统,并进行集成 测试。在集成的过程中发现了一些错误,比如全局变量重复定义、函数重复声明等,分别进行了改正。最后连续运行了5次,以便测试该游戏程序的功能、性能是否达到了预
21、期 的目标,并根据所使用的具体机器对蛇的爬行速度进行适当的调整。测试内容包括蛇的运行、分数、 关数、排行榜及排序、文件存储,音乐动画等功能,情况均正常。六.结论终于完成了贪吃蛇游戏程序的开发任随机产生食物、控制蛇吃掉食物并加通过2周的课程设计,在开发小组共同的努力下, 务。该游戏程序实现了用方向键控制蛇在围墙内爬行、 分、控制游戏中闯关的数目和蛇的运行速度、实时显示得分和关数、结束时处理和显示排行榜等 功能。该游戏程序具有界面友好、操作方便、控制准确和容错能力强等特点。这个贪吃蛇游戏还存在一些缺陷,还应该在如下几个方面加以改进。1)进入游戏后,到蛇死亡,只能玩一次就会退出程序。应加入多次游戏的
22、控制能力。2)蛇的样子不美观,应将蛇头、蛇尾和蛇身进一步美化,使其更像真实的蛇。3)当分数达到400分时,蛇的速度变得非常快,一下子就撞到围墙上了,应适当控制蛇的速度和关数,以便使游戏更具有吸引力。七.结束语贪吃蛇游戏的编程练习思考数据结构:定义食物的坐标来控制它出现的位置,用一系列来的函数时进行表示,比如用函数 rectangle画出矩形,用life变量的值表示蛇的生命,用 direction变量的值表示蛇移动的方向等,还有用数组来存放蛇身各节的坐标,这些都让我们熟悉了对数组的操作,此外还熟悉了各种函数的应用。贪吃蛇的设计有很多帮助,学习编写贪吃蛇的游戏对掌握c语言的知识有很大的帮助。通过编
23、程实践,还能拓展思路,让我们去寻找需要调用那些函数,怎样提高程序的质量等。 要写出好的程序,需要我们有扎实的基础,这样遇到一些基本算法的时候就会游刃有余了。在编程时我们要有丰富的想象力,不要拘泥与固定的思维方式,遇到问题的时侯要多想几种解决问题的方案。丰富的想象力是建立在丰富的知识基础上,所以我们要通过多个途径来帮助自己建立较丰富的知识结构。在编程是我们碰倒了很多的困难,这就需要我们多与别人交流。在编程的过程中,我们也发现有良好的编程风格是十分重要的,至少在时间效率上就体现了这一点。养成良好的习惯,代码的缩进编排,变量的命名规则要始终保持一致,这些都是提高我们编程能力的要点。在进行课程设计的过
24、程中我们也学到了许多别的东西。首先,我们学会了合作,要以别人的眼光看看问题,也许这样得到的会比各自得到的都要多;其次,我们学会了分工,分工是为了更好地合作,分工才能提高合作的效率;最后,我们学会了奋斗,我们相信,通过 四年的学习,我们一定能写出更精彩的程序,将来会描绘出更精彩的人生。在这里,我们要感谢指导课程设计的张凤君老师,给予我们悉心的指导。老师多次询问编写进程,并为我们指点迷津,帮助我们开拓研究思路,精心点拨、热心鼓励。老师一丝不苟 的工作作风,严谨求实的态度,踏踏实实的精神,不仅受我以文,而且教我做人,给以终生受益无穷之道。我还要感谢我们开发小组的其他同学,在设计中他们给我很大的帮助。
25、正是由 于我们团结协作,才顺利的完成了课程设计任务。八.程序清单/*贪吃蛇游戏程序清单*/#include#include# include #include#include# include #include#include# define filename c:person.datu/* 排行榜文件的文件全名*/# deiine esc 0x011 b/髭sc 键 */# detine n 200 /*蛇的最大节数*/# define left 0x4b00/* 左移方向键 */# define right 0x4d00/* 右移放向键 */# detine down 0x5000/* 下
26、移方向键 */# define up 0x4800/* 上移方向键 */*排行榜结构体*/struct personint score;/*游戏者分数*/char name 20;/* 游戏者姓名 */per5;/*小蘑菇结构体*/*自定义的函数声明*/void drawmogu(); /* 动画音乐函数 */void readfileso; /*从文件中读取记录信息*/void write files (struct person *) ;/* 将纪录写入文件中*/void inits core file s();/* 初始化记录文件 */void compare score (struct
27、 person); /* 排行榜按分数进行排序 */void endplay(); /*游戏结束处理函数 */void paihb(); /*绘制排行榜函数*/*输出欢迎词并播放声音函数*/void pr() int s15=0,100,150,200,250,300,250,150,100,250,350);setcolor(change/10);/* 改变欢迎词颜色 */sette xtstyle (0,0,4);outtextxy(20,200,nwelcome to our game);/* 输出欢迎词 */ sound(schange/l。);/*使扬声器以括号内的频率发声*/)/*
28、下雪的动画并同步播放音乐函数*/void draws now() int i;int sx62;selinestyle(solid_line,0,thick_width);一次3行画出白色雪花的3条线*/line(0,5,10,5);line(9,l,l,9);save=manoc(200);/*在堆中申请 200字节空间*/getimage ( 0,0,10,10, save ) ;/* 将雪花位图保存到save 中*/cleardevice();/* 清屏 */randomize。;/*设置随机种子数*/for(i=0;i62;i+)sxi=(i+2)*10/*计算雪花位置的横坐标数组*/
29、*以下的键控while循环控制播放音乐和下雪动画*/while(!kbhit()/*如果未按键,执行循环体 */ pr();/*调用pr函数输出欢迎词并播放声音 */if(snownum!=100)snowsnownum.speed=2+random(5);i=random(62);snowsnownum.x=sxi;/* 取横坐标 */snowsnownum.y=10-random(100);/* 取纵坐标 */ /*循环放置snownum个雪花*/for(i=o;is nownum ;i+)putimage(snowi.x,snowi.y,save,copy_put); delay(loo
30、);/*延迟100ms以便看到雪花 */ cleardevice。;/* 清屏 */pr();/*调用pr函数输出欢迎词并播放声音*/if(snownum !=100) snownum+4-;s e tfius tyle (s olid_fill,15);tor(i=0;i500)snowi.y=10-random(200);)change+;if(change=140) change=10;)nosound(); /*关闭扬声器*/cleardevice();/* 清屏 */)/*图像系统初始化函数*/void init(void)int gd=detect,gm;initgraph(&gd
31、,&gm,nc :wtc3bgr);cleardevice(); /* 清屏 */)/*游戏开始界面,左上角坐标为( 50, 40),右下角坐标( 610, 460)的围墙*/ void drawk(void)(int i;setcolor(blue);setunestyle(solid_line,0,thick_width); /* 设置线性 */for(i=50;i=600;i+=10)/* 用循环画围墙 */setcolor(2*i+l);circle(i,40,5);/* 画上边 */circle(i,451,5);circle(i,460,5);/* 画下边 */)for(i=40;
32、i=450;i+=10)setcolor(2*i+l);circle(50,i,5);/* 画左边 */circle(601,i,5);)for(i=40;i0;i)s n a ke. x i=s n a ke. x i-1 ;snake .yi=snake.yi-l ;)、2、3、4表示右、左、上、下四个方向,通过这个判断来移动蛇头*/switch(snake.direction)case 1 :snake.x0+=10;break;case 2:snake.x0-=10;break;case 3:snake.y0-=10;break;case 4:snake.y0+=10;break;)/
33、*判断蛇是否撞到墙*/if(snake.x0595llsnake.y0445)snake.life = l;/*置蛇死标志 */break;)/*从蛇的第四节开始判断是否撞到自己,*/fbr(i=3 ;isnake .node ;i+)if(s nake ,xi=s nake .x0&s na ke .yi=s na ke .y0)snake.life=l; /* 置蛇死标志 */ break;)if(snake.ufe=l) /*以上两种判断以后,如果蛇死就跳出内循环*/break; /*跳出 while(!kbhit)*/if(snake.x0=food.x&snake.y0=food.y
34、)/* 吃到苹果以后 */setcolor(black);/*把画面上的苹果擦除*/circle (food.x,food.y,5);snake.node+;/*蛇的身体长一节 */tbod.yes = l; /*画面上需要出现新的苹果 */score+=10; /*没吃一个苹果增加 10分*/if(score%50=0)/*吃够5个苹果进入下一关 */level+=l; /* 关数加 1*/ gamespeed-=60;/*控制速度的值减少60,以便加快速度 */)setcolor(red); /*画出红色蛇的循环*/setfiustyle(solid_fill,red);/* 用圆画出红色
35、蛇头 */tillellipse(snake.x0,snake.y0,5,5);setcolor(green);s e tfills tyle (s olid_line,green);circle(snake.x0,snake.y0, 1);/*对蛇头填充绿色小圆作为眼睛*/setcolor(red);s e tfills tyle (s oled_fill,blue);tbr(i=l ;isnake.node;i+) /* 用圆画出红色蛇身 */ setcolor(red);s e tfills tyle (s olid_fill,blue);fille llipse(snake.xi,sn
36、ake.yi,5,5);/* 对每节蛇身用蓝色填充*/setcolor(cyan);circle(snake.xi,snake.yi,l); /*用青色小圆画在每节蛇身上 */delay(gamespeed); /*延迟gamespeed毫秒,以便控制蛇的爬行速度*/setcolor(black);/*用背景色黑色去除蛇的最后一节*/circle(snake.xsnake.node-l,snake.ysnake.node-l,5);s e trills tyle (s oled_fill,blac k);fille llipse(snake.xsnake.node-l,snake.ysnake
37、.node-l,5,5); )if(snake.life=l) break; /*如果蛇死就跳出循环 */key=bioskey(0);/* 接收按键 */if(key=esc) break; /* 按 esc 键退出 */*判断是否往相反的方向运动*1else if(key=upnake.direction!=4)snake.direction=3;else if(key=right&snake.direction!=2) snake.direction=l;else irkey=left&snake.direction!= 1)snake.direction=2;else if(key=d
38、own&snake.direction!=3) snake.direction=4;/足 ndwhile(l)*/y*结束游戏*/*读取文件操作函数*/void readfiles()file *ipread;/*如果文件不存在,则创建 1个空文件,否则打开该文件 */if(ipre ad=tbpe n(filename ,nab+)=null)printcanft open the file person.dat!);exit(o);)if(lgetc(tpread)=eof)/* 如果文件内容为空*/inits core file s();/*调用函数进行记录初始化工作*/rewind(i
39、pread);/*重新复位文件位置指针*/fread(per,sizeobstruct person),5,fpread); fclose(ipread); /*关闭排行榜文件*/ )/*写入文件操作函数*/void write files (struct person *tmp)file * ip write;/*以读写方式打开文件,文件内原有的数据将被清空*/if( (ip write =fopen(file na me ,wb+)=null)printf(,cant,t open the file person.dat!);exit(o);fwrite(tmp,sizeof(struct
40、 person ),5,ip write);fclose (ip write);/*初始化记录函数*/void inits core file s()int i;struct person a 5;for(i=0;i5;i+)ai.score=0; 1*5 人的分数为 0*/strcpy(,nobodyh); /*5 人的名为 nobody*/ )write tiles (a);/*调用记录写入函数*/)/*排序函数,如果玩家分数超过最低记录,则将玩家分数插入到合适的位置,同时删除原 先的最低记录*/void comparescore(struct person des)int i,j;for(i=0;l=peri.score)if(i=i+l;j-) perj=perj-l;) peri=des; break;/*显示排行榜信息*/void pailib()int i;char string10;readfilesq; /*调用读取文件中存在的记录函数*/setfillstyle(l ,9);bar(482,227,599,239);1*1outtextxy(490,230,highest board );/* 输出此文本 */setcolor(15);rectangle(480,255,600,240);/* 画矩形 */
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 【正版授权】 IEC 60068-2-30:2005 FR-D Environmental testing - Part 2-30: Tests - Test Db: Damp heat,cyclic (12 h + 12 h cycle)
- 高铁动车组维修保养规范及流程
- 《光的折射与反射现象:小学自然常识实验教案》
- 音响考试试题及答案
- 六一入队活动方案
- 六一寻宝活动方案
- 六一患儿活动方案
- 六一果冻活动方案
- 六一活动具体活动方案
- 六一活动方案
- 《基础护理学》给药课件
- 绘本故事三只小猪盖房子课件
- 《WPS办公应用职业技能等级》课件-1. WPS初级-文字
- 抗日战争与中国的文化自觉
- QB∕T 1744-2013 电热毯、电热垫及类似柔性发热器具用非织造针刺毯
- 中国人民大学强基计划文科试卷
- 生物-云南省昆明市2023-2024学年高二下学期期末质量检测试题和答案
- 幼儿园小班语言课件:《池塘夏夜》
- 虹吸式雨水排水系统施工方案
- 北京草场改造规划方案
- 水利施工安全培训课件
评论
0/150
提交评论