运动会成绩管理系统.doc

上传人:仙人指路1688 文档编号:3799080 上传时间:2023-03-22 格式:DOC 页数:26 大小:440KB
返回 下载 相关 举报
运动会成绩管理系统.doc_第1页
第1页 / 共26页
运动会成绩管理系统.doc_第2页
第2页 / 共26页
运动会成绩管理系统.doc_第3页
第3页 / 共26页
运动会成绩管理系统.doc_第4页
第4页 / 共26页
运动会成绩管理系统.doc_第5页
第5页 / 共26页
点击查看更多>>
资源描述

《运动会成绩管理系统.doc》由会员分享,可在线阅读,更多相关《运动会成绩管理系统.doc(26页珍藏版)》请在三一办公上搜索。

1、题目: 运动会成绩管理系统实验报告指导教师: 班 级 : 学 号 : 学生姓名 : 专 业 : 2011年11月目录(一)主要内容2(二)基本要求2摘要11.绪论12.系统分析12.1功能需求12.2数据需求22.3性能需求23.总体设计23.1功能模块设计23.2系统设计方案34详细设计44.1录入信息模块44.2查询信息模块64.3修改信息模块74.4删除信息模块84.5成绩排名模块105调试和测试125.1测试125.2调试126.结论137、结束语138、附录源程序13一、 课程设计的内容及要求: (一)主要内容设计一个运动会成绩管理程序,主要实现以下功能:1、 检录功能,登录参赛运动

2、员的信息;2、 记录成绩功能,每项比赛结束后记录参赛运动员的成绩;3、 针对不同比赛对运动员的成绩排名次;4、 可对运动员的信息和成绩进行修改、删除、查询操作。 (二)基本要求1、 系统采用所学相关课程中编辑程序设计语言实现;2、 独立完成系统的设计、编码和调试,通过指导教师当场验收;3、 交出完整的课程设计报告。摘要运动会是一个全民健身的活动,在运动会里可以提高人们的身体素质,培养人们的素养。在参加运动会的过程中我们可以看到激情和友情的碰撞,人们用自己的实力来赢得第一。开发本系统是为了更方便,在运动会中做比赛数据的记录,方便记录比赛成绩。本系统使用C语言作为开发语言。实现了对运动会的结果提示

3、以及对成绩的储存和对成绩的排名。本文从分析课题的题目背景、题目意义、题目要求等出发,分别从需求分析、总体设计、详细设计、测试等各个方面详细介绍了系统的设计与实现过程,最后对系统的完成情况进行了总结。关键词:C语言;运动会;信息管理 1.绪论运动会成绩管理程序设计的开发是为了方便记录比赛成绩,运动员的状况和成绩,对比赛成绩进行排名。这个系统以快捷,简便为原则,更加方便了对运动会成绩的记录。运动会是很早以前就有的一项组织性活动,它的存在使人们的身体得到了锻炼。运动会是一项必不可少的活动,所以开发这个系统可以使运动会成绩的记录变的更加方便。设计一个运动会成绩管理程序,主要实现以下功能:1、检录功能,

4、登录参赛运动员的信息;2、记录成绩功能,每项比赛结束后记录参赛运动员的成绩;3、针对不同比赛对运动员的成绩排名次;4、可对运动员的信息和成绩进行修改、删除、查询操作。2.系统分析2.1功能需求 本系统要求对运动员的信息进行登录修改,记录,查询,要求可以对运动员的成绩进行单项排名。主要实现程序最初运行时运动员数据的录入以及其后的运行数据的追加功能,实现的功能是按照号码对运动员的数据记录进行修改、记录、查询、删除,按照题目的具体要求实现的是某项成绩的递减排序以及名次显示。 2.2数据需求在这些函数当中,添加运动员数据函数例如运动员序号、运动员名称、百米赛跑成绩、三级跳成绩和撑杆跳成绩。 2.3性能

5、需求本系统的性能需求:要求运行稳定、数据可靠、输出准确、响应速度快、可安全运行、能很好的保存、删除、修改。可以及时保存存储删除数据,可对成绩进行排名,显示即时成绩3.总体设计3.1功能模块设计经过对程序设计题目的分析可知,整个程序的设计实现大致分为5个模块,每一个模块对应一个函数。在这些函数当中,添加运动员数据函数,删除数据函数,某项成绩排序函数的实现严格按照题目的要求,而更改数据函数和显示函数属于附加功能。读取文件函数和保存信息函数对其它函数的实现起辅助作用,主函数及菜单函数控制程序的整体运行。录入信息模块是录入运动员信息、查询信息模块是查询运动员信息的、修改信息模块可以对运动员信息进行修改

6、、删除模块可对运动员信息进进行删除、成绩排名是对运动员的成绩进行排名,功能模块见图1所示。图1 功能模块图3.2系统设计方案本系统中用到了结构体数组和数据的存储。该结构体数组中包含字符串,系统的设计方案如下:(1)数据结构struct studentchar num20;/运动员号码 char name10;/运动员名字 float baimi;/百米赛跑成绩 float sanjitiao;/三级跳成绩 float chenggantiao;/撑杆跳成绩;(2)菜单设计一个总菜单,0、查询运动员数据;1、添加运动员数据;2、显示运动员数据;3、删除运动员数据;4、修改运动员数据;5、百米成绩

7、排序;6、三级跳成绩排序;7撑杆跳成绩排序;8、退出;基本功能的实现都将体现在这几个菜单选项中。(3) 函数定义了12个函数void menu();int reads(struct student stuN);/读取运动员信息void save(struct student stuN,int n);/储存运动员信息void search();/查询运动员信息void add();/添加运动员信息void del();/删除运动员信息void sort();/ 按百米赛跑成绩查询void keep();/按三级跳成绩查询void sheep();/按撑杆跳成绩查询void query();/退出

8、程序void show();/显示运动员信息void change();/更改运动员信息4详细设计4.1录入信息模块1. 添加数据函数添加数据分为两种情况,其一是在运动员文件(student.txt)不存在的情况下,首先由程序创建一个新文件,并将录入的运动员信息写入该文件当中;其二是在运动员文件(student.txt)已经存在的情况下,此时文件以追加的方式打开,这样才可以保证以前已经存在的数据不丢失。 图2录入信息流程图4.2查询信息模块查询文件是在以存的运动员信息中进行查询,可对运动员信息进行查询显示运动员信息。通过录入运动员号码num ,与stui.num做比较,结果相同进行m+,m=r

9、eads(stu);来提取文件中的数据图3查询信息流程图4.3修改信息模块修改信息是对运动员信息进行修改,通过输入number与stui.num比较,如果相同进行 n=reads(stu)来提取信息在对信息进行修改。 图4修改信息流程图4.4删除信息模块该函数的核心内容是删除算法以及最终对源文件的更新。该函数执行时,首先调用reads函数将文件中的运动员信息读入数组当中,并由用户输入待删除运动员的号码,而后按照该号码进行查找,如果文件中存在该运动员的数据,则采用删除算法删除,否则输出运动员信息不存在的提示信息。对运动员信息的具体删除算法是在结构体数组中实现的,当运动员的信息被找到后,位于数组中

10、该学生后面的运动员记录依次向前移动一个元素的位置,这些操作完成后,要删除运动员信息就被后面的数组元素覆盖掉了,也就实现了删除。 图5删除信息流程图4.5成绩排名模块对于某项的排序采用的排序算法是冒泡法排序,整个排序过程在结构体数组stu中实现,由于排序算法涉及到两个数组元素的信息交换,因此还需要定义一个中间变量来协助。排序函数使运动员数据的排列顺序发生了变化,因此也需要对源文件进行更新。此外,对于运动员排序后名次的确定,仅在结果输出时予以显示,并未将名次信息写入源文件。具体的程序段如下(由于各项成绩排序函数相同,所以只给出百米赛跑排名程序): 图6成绩排名流程图5调试和测试5.1测试 测试是在

11、完成某一部分功能和全部功能后,根据功能和性能的需求,看看系统有没有实现要求中的功能,是否达到性能要求。系统测试是软件生存期中的一个重要阶段,系统质量保证的关键步骤从用户的角度来看,普遍希望通过软件测试暴露软件中隐藏的错误和缺陷,所以系统测试应该是“为了发现错误而执行程序的过程”。或者说,系统测试应该根据程序开发各阶段的规格说明和程序的内部结构而精心设计一批测试用例(即输入数据及其预期的输出结果),并利用这些测试用例去运行程序,以发现程序错误或缺陷。过度测试则会浪费许多宝贵的资源。到测试后期,即使找到了错误,然而付出了过高的代价。测试数据过程如下。当运动员成绩管理系统进行对运动员数据的添加数据

12、号码 1 姓名 zhanglinlin 百米赛跑 10 三级跳 9 撑杆跳 4.5 号码 2 姓名 yushuo 百米赛跑 9.8 三级跳 7 撑杆跳 4。显示信息即显示添加的数据 ,修改数据,查询数据,现在测试系统是否能够正确显示录入的所有运动员信息,当系统中已存入一定的运动员信息当执行浏览功能时,系统会将运动员信息全部列出,当系统未存入任何信息是显示无运动员信息 。测试成功,显示正确,完成测试。5.2调试 调试是程序编写中的一个重要环节,也是最复杂,对程序编写者来说是一项艰巨的任务。调试的任务就是及时改正测试过程中发现的错误。具体地说,调试过程由两个步骤组成,它是从程序中存在错误的某种迹象

13、开始的。首先是确定错误的准确位置,也就是找出是哪个模块或哪个语句引起的错误。然后仔细研究推断代码以确定问题的原因,并设法改正。调试过程主要是运行编制好的程序,然后遇到错误后根据系统的提示,找到相关的问题所在。本系统调试过程中遇到问题、原因和解决方法如下面介绍:(1)程序运行不顺利在程序运行的过程中出现死循环、不运行和提前结束。原因是程序中出现了逻辑错误,进入查询页面后,查询的时候显示的是逻辑错误。没有写读取文件的函数m=reads(stu);所以读取不了存储的文件(2)无法将排完序的数据写入到文本文件stu_list.txt中去原因是读写文件的方式不对。6.结论经过一段时间的学习,制作我的运动

14、会成绩管理系统完成了,但只能说是粗略的完成。虽然说还存在一写不足的地方,但基本实现了任务说上得所有要求,发现错误并及时修改,她能够统计学生的比赛成绩和通过成绩进行排名,我设计的成绩还存在一定的不足,一开始是没有查询功能的 ,经过我不断地努力把程序进行了完善,让它变的更加实用。7、结束语经过两个星期的思考,设计,编程,我真的感到这不是一件简单容易的事情。C语言综合训练考察的并不仅仅是我们的基础知识,还有思维上得活跃性,创新性,以及我们的动手能力。让我了解到要想又好又快地完成一个程序,必须要有坚实的基础和认真的编写过程。在写本程序的过程中我对文件中数据的排序有了深刻的认识,并且学会指针的选择排序,

15、但是不会将文件中的某一个数据删除。8、附录2源程序主要模块的源代码清单:#include#include#include#includeconio.h#define N 20struct studentchar num20; char name10; float baimi; float sanjitiao; float chenggantiao;void menu();int reads(struct student stuN);void save(struct student stuN,int n);void search();void add();void del();void sort

16、(); void keep();void sheep();void query();void show();void change();int reads(struct student stuN) / 读取运动员文件中的内容 FILE *fp; int i=0; if(fp=fopen(c:student.txt,r)=NULL) printf(文件打开失败!n); return 0; else for(i=0;!feof(fp);i+) fscanf(fp,%s %s %f %f %fn,stui.num,stui.name,&stui.baimi,&stui.sanjitiao,&stui

17、.chenggantiao); fclose(fp); return i;void save(struct student stuN,int n) / 运动员信息改变后更新文件 FILE *fp; int i=0; if(fp=fopen(c:student.txt,w)=NULL) printf(文件打开失败!n); return ; else for(i=0;in;i+) fprintf(fp,%s %s %f %f %fn,stui.num,stui.name,stui.baimi,stui.sanjitiao,stui.chenggantiao); fclose(fp);void se

18、arch()/查询运动员信息 int i=0,m; char num20; struct student stuN; m=reads(stu); printf(请输入运动员号码:); scanf(%s,num); printf(号码t姓名t百米赛跑t三级跳t撑杆跳tn); for(i=0; im; i+) if(strcmp(stui.num,num)=0) printf(n%12s%11s%11.2f%12.2f%11.2fn,stui.num,stui.name,stui.baimi,stui.sanjitiao,stui.chenggantiao); m+; printf(-n);voi

19、d add()/*添加运动员信息*/ FILE *fp; int n,i; struct student stu; if(fp=fopen(c:student.txt,a)=NULL) /如果文件已经存在,可以追加学生信息 if(fp=fopen(c:student.txt,w)=NULL) / 文件不存在时,创建新文件,输入学生信息 printf(文件打开失败!n); return; printf(请输入要添加的运动员数量,按回车键确认:); scanf(%d,&n); for(i=1;i=n;i+) printf(n请输入第%d个运动员的号码、姓名,用空格分开,并按回车键确认:n,i);

20、scanf(%s%s,stu.num,stu.name); printf(n请输入第%d个运动员的百米赛跑、三级跳和撑杆跳三项成绩,用空格分开,并按回车键确认:n,i); scanf(%f%f%f,&stu.baimi,&stu.sanjitiao,&stu.chenggantiao); fprintf(fp,%s %s %f %f %fn,stu.num,stu.name,stu.baimi,stu.sanjitiao,stu.chenggantiao); fclose(fp);void show() / 运动员信息显示函数 struct student stuN; int i,n; n=r

21、eads(stu); printf(*所有的学生信息如下*nn); printf( 序号 号码 姓名 百米赛跑 三级跳 撑杆跳 n); printf(*n); for(i=0;in;i+) printf(n%12s%11s%11.2f%12.2f%11.2fn,stui.num,stui.name,stui.baimi,stui.sanjitiao,stui.chenggantiao); getch();void del() /*运动员信息删除函数*/ struct student stuN; char number20; int n,i,j; n=reads(stu); printf(n请输

22、入要删除信息运动员号码,按回车键确认:); scanf(%s,number); for(i=0;i=n) printf(没有找到该运动员信息!n); return; else for(j=i+1;jn;j+) stuj-1=stuj; save(stu,n-1); printf(删除成功!n);void change() /学生信息更改 struct student stuN; int n,i; char number20; printf(n请输入要更改信息的学生学号,按回车键确认:); scanf(%s,number); n=reads(stu); for(i=0;i=n) printf(无

23、此学生信息!); return; printf(n请输入更改后学生的号码,姓名,百米赛跑、三级跳、撑杆跳三门成绩,按回车键确认:n); scanf(%s%s%f%f%f,stui.num,stui.name,&stui.baimi,&stui.sanjitiao,&stui.chenggantiao); save(stu,n);void sort() / 按百米赛跑成绩排名struct student stuN,temp;int i,j,n;n=reads(stu);for(i=0;in-1;i+)for(j=0;jstuj+1.baimi)temp=stuj;stuj=stuj+1;stuj

24、+1=temp;save(stu,n); j=1 ; printf(*百米赛跑成绩排序结果如下*nn); printf( 名次 号码 姓名 百米赛跑 成绩 n); printf(*n); for(i=0;in;i+) / 输出结果并排名 if(stui.baimi=stui+1.baimi) if(stui.baimi!=0)printf(n%3d%12s%11s%11.2f%11.2fn,j,stui.num,stui.name,stui.baimi,stui.baimi); elseprintf(n%3d%12s%11sttttn,j,stui.num,stui.name); else p

25、rintf(n%3d%12s%11s%11.2f%11.2fn,j+,stui.num,stui.name,stui.baimi,stui.baimi); getch();void keep() / 按三级跳成绩排名struct student stuN,temp;int i,j,n;n=reads(stu);for(i=0;in-1;i+)for(j=0;jn-1;j+)if(stuj.sanjitiaostuj+1.sanjitiao)temp=stuj;stuj=stuj+1;stuj+1=temp;save(stu,n); j=1 ; printf(*三级跳成绩排序结果如下*nn);

26、printf( 名次 号码 姓名 三级跳 成绩 n); printf(*n); for(i=0;in;i+) / 输出结果并排名 if(stui.sanjitiao=stui+1.sanjitiao) printf(n%3d%12s%11s%11.2f%11.2fn,j,stui.num,stui.name,stui.sanjitiao,stui.sanjitiao); else printf(n%3d%12s%11s%11.2f%11.2fn,j+,stui.num,stui.name,stui.sanjitiao,stui.sanjitiao); getch();void sheep()

27、/ 按三级跳成绩排名struct student stuN,temp;int i,j,n;n=reads(stu);for(i=0;in-1;i+)for(j=0;jn-1;j+)if(stuj.chenggantiaostuj+1.chenggantiao)temp=stuj;stuj=stuj+1;stuj+1=temp;save(stu,n); j=1 ; printf(*撑杆跳成绩排序结果如下*nn); printf( 名次 号码 姓名 三级跳 成绩 n); printf(*n); for(i=0;in;i+) / 输出结果并排名 if(stui.chenggantiao=stui+1

28、.chenggantiao) printf(n%3d%12s%11s%11.2f%11.2fn,j,stui.num,stui.name,stui.chenggantiao,stui.chenggantiao); else printf(n%3d%12s%11s%11.2f%11.2fn,j+,stui.num,stui.name,stui.chenggantiao,stui.chenggantiao); getch();void menu() printf(n * 运动员成绩管理系统* ); printf(n * 0 查询运动员数据 *); printf(n * 1 添加运动员数据 *);

29、printf(n * 2 显示运动员数据 *); printf(n * 3 删除运动员数据 *); printf(n * 4 更改运动员数据 *); printf(n * 5 百米成绩排序 *); printf(n * 6 三级跳成绩排序 *); printf(n * 7 撑杆跳成绩排序 *); printf(n * 8 退出 *); printf( n *);void main() int n; while(1) menu(); printf(n 请输入您要选择的操作序号,按回车键确认:); scanf(%d,&n); switch(n) case 0:search();break; case 1: add();break; case 2: show();break; case 3: del();break; case 4: change();break; case 5: sort();break; case 6: keep();break; case 7 :sheep();break; case 8: exit(0); default: printf(输入错误,请输入列表中存在的序号!n );

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 办公文档 > 其他范文


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号