C语言课程设计运动会成绩管理系统.docx
C语言课程设计运动会成绩管理系统课程设计任务书 题目:运动会成绩管理系统(1) 一、课程设计时间 共计1周,20学时。 二、课程设计内容 用C语言编写软件完成以下任务: 1 录入运动员信息; 2 按所参加的项目添加成绩; 3 某一项目按成绩排名。 三、课程设计要求 1. 程序质量: ² 贯彻结构化的程序设计思想。 ² 用户界面友好,功能明确,操作方便。 ² 用户界面中的菜单至少应包括“运动员信息录入”、“按项目添加成绩”、“按成绩排名”、“退出”4项。 ² 代码应适当缩进,并给出必要的注释,以增强程序的可读性。 2. 课程设计说明书: 课程结束后,上交课程设计说明书和源程序。课程设计说明书的格式和内容参见提供的模板。 四、指导教师和学生签字 指导教师:_ 学生签名:_ 五、说明书成绩 1 目 录 一、需求分析 . 1 二、程序流程图 . 2 三、核心技术的实现说明及相应程序段 . 4 四、课设总结 . 8 五、源程序 . 9 I 一、需求分析 经过对程序设计题目的分析可知,整个程序的设计实现大致分为十一个模块,每一个模块对应一个函数。在这些函数当中,添加运动员数据函数,删除数据函数,某项成绩排序函数的实现严格按照题目的要求,而更改数据函数和显示函数属于附加功能。读取文件函数和保存信息函数对其它函数的实现起辅助作用,主函数及菜单函数控制程序的整体运行。 1. 添加运动员数据函数 主要实现程序最初运行时运动员数据的录入以及其后的运行中学生数据的追加功能; 2. 删除运动员数据函数 实现的功能是按照号码对运动员的数据记录进行删除; 3. 排序函数 按照题目的具体要求实现的是某项成绩的递减排序以及名次显示,其中总成绩相同者名次相同; 4. 更改数据函数 可以实现对运动员的各项信息进行修改; 5. 显示函数 实现的是显示目前所有的有效运动员记录信息。 除上面介绍的功能之外,程序还具有退出功能,可以在程序的一次运行当中循环执行所有的功能,并根据需要终止程序的执1 行。 每一个运动员记录都包含号码、姓名,以及百米赛跑、三级跳和撑杆跳三门成绩,在程序当中,将运动员记录类型定义为结构体类型,添加以及追加的运动员信息直接写入E盘的student.txt文件中,其它函数每次对运动员记录的访问,其数据来源都是student.txt文件,这样做不但可以保证运动员数据的一致性,而且可以对运动员数据进行永久保存,保证每次运行程序都可以采用原来的数据。 二、程序流程图 1. 程序总体结构图 2 当1 真 输入值n=1? 假 n=2? 真 假 n=3? 添加 真 假 运动 n=4? 员信显示运 真 假 息函动员信删除 n=5? 数息函数函数更新函真 假 add show del 数 ? change 真 假 百米 n=7? 排序三级真 假 函数跳排撑杆跳 sort 序排序 退出 sort 函数 Sort 图1程序总体结构图 2. 排序功能框图 排序函数sort 3 n=reads(stu)循环变量i=0当i<n-1时j=0当 j<n-1-i 时真第j个运动员成绩<第j+1个运动员成绩假交换两个运动员信息 j+i+调用更新文件函数save(stu,n)i=0当 i<n 时输出运动员信息和排名情况i+成绩排序 j+三、核心技术的实现说明及相应程序段 本程序主要由10个自定义函数和一个主函数组成,其中主函数以菜单的形式调用其它函数来实现要求的所有功能。在这些函数当中,添加学生数据函数、删除数据函数和排序函数是程序中较为核心的部分,下面分别进行说明。 1. 添加数据函数 4 添加数据分为两种情况,其一是在运动员文件不存在的情况下,首先由程序创建一个新文件,并将录入的运动员信息写入该文件当中;其二是在运动员文件已经存在的情况下,此时文件以追加的方式打开,这样才可以保证以前已经存在的数据不丢失。具体的程序段如下: FILE *fp; int n,i; struct student stu; if(fp=fopen("e:student.txt","a")=NULL) /如果文件已经存在,可以追加学生信息 if(fp=fopen("e:student.txt","w")=NULL) / 文件不存在时,创建新文件,输入学生信息 printf("文件打开失败!n"); return; printf("请输入要添加的运动员数量,按回车键确认:"); scanf("%d",&n); for(i=1;i<=n;i+) printf("n请输入第%d个运动员的号码、姓名,用空格分开,并按回车键确认:n",i); scanf("%s%s",stu.num,stu.name); printf("n请输入第%d个运动员的百米赛跑、三级跳和撑杆跳三项成绩,用空格分开,并按回车键确认:n",i); scanf("%f%f%f",&stu.baimi,&stu.sanjitiao,&stu.chenggantiao); 5 fprintf(fp,"%s %s %f %f %fn",stu.num,stu.name,stu.baimi,stu.sanjitiao,stu.chenggantiao); fclose(fp); 2. 删除数据函数 该函数的核心内容是删除算法以及最终对源文件的更新。该函数执行时,首先调用reads函数将文件中的运动员信息读入数组当中,并由用户输入待删除运动员的号码,而后按照该号码进行查找,如果文件中存在该运动员的数据,则采用删除算法删除,否则输出运动员信息不存在的提示信息。对运动员信息的具体删除算法是在结构体数组中实现的,当运动员的信息被找到后,位于数组中该学生后面的运动员记录依次向前移动一个元素的位置,这些操作完成后,要删除运动员信息就被后面的数组元素覆盖掉了,也就实现了删除。在数组中删除运动员信息后,还要将更改后的信息重新写回文件当中,以保证数据的一致性。具体程序段如下: struct student stuN; char number20; int n,i,j; n=reads(stu); printf("n请输入要删除信息运动员号码,按回车键确认:"); scanf("%s",number); 6 for(i=0;i<n;i+) if(strcmp(number,stui.num)=0) break; if(i>=n) printf("没有找到该运动员信息!n"); return; else for(j=i+1;j<n;j+) stuj-1=stuj; save(stu,n-1); printf("删除成功!n"); 3. 总分排序函数 对于某项的排序采用的排序算法是冒泡法排序,整个排序过程在结构体数组stu中实现,由于排序算法涉及到两个数组元素的信息交换,因此还需要定义一个中间变量来协助。排序函数使运动员数据的排列顺序发生了变化,因此也需要对源文件进行更新。此外,对于运动员排序后名次的确定,仅在结果输出时予以显示,并未将名次信息写入源文件。具体的程序段如下: void sort / 按百米赛跑成绩排名 struct student stuN,temp; int i,j,n; 7 n=reads(stu); for(i=0;i<n-1;i+) for(j=0;j<n-1;j+) if(stuj.baimi<stuj+1.baimi)temp=stuj;stuj=stuj+1;stuj+1=temp; save(stu,n); j=1 ; printf("*百米赛跑成绩排序结果如下*nn"); printf(" 名次 号码 姓名 百米赛跑 成绩 n"); printf("*n"); for(i=0;i<n;i+) / 输出结果并排名 if(stui.baimi=stui+1.baimi) printf("n%3d%12s%11s%11.2f%11.2f%11.2f%11.2fn",j,stui.num,stui.name,stui.baimi,stui.baimi); else printf("n%3d%12s%11s%11.2f%11.2f%11.2f%11.2fn",j+,stui.num,stui.name,stui.baimi,stui.baimi); getch; 四、课设总结 这是大学以来的第一次上课程设计,感受很多,收获也很多。其中最重要的是做什么事都要自己动手,动脑。不要依赖同学,8 只有这样才能增长自己的知识,同时也对C语言有了进一步的了解和认识,以前许多不懂得地方,通过这次课设都懂了。在做程序时,很是费脑筋,幸亏有老师的参考程序,给了不少的帮助,使得课程设计顺利的完成。 五、源程序 #include<stdio.h> #include<stdlib.h> #include"conio.h" #define N 20 struct student char num20; char name10; float baimi; float sanjitiao; float chenggantiao; ; void menu; int reads(struct student stuN); void save(struct student stuN,int n); void add; void del; void sort; void keep; void sheep; void query; void show; void change; void main int n; while(1) 9 menu; printf("n 请输入您要选择的操作序号,按回车键确认:"); scanf("%d",&n); switch(n) 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 "); void menu printf(" * 运动员成绩管理系统* "); printf("n O(_)O 1 添加运动员数据 O(_)O"); printf("n O(_)O 2 显示运动员数据 O(_)O"); printf("n O(_)O 3 删除运动员数据 O(_)O "); printf("n O(_)O 4 更改运动员数据 O(_)O "); printf("n O(_)O 5 百米成绩排序 O(_)O "); printf("n O(_)O 6 三级跳成绩排序 O(_)O "); printf("n O(_)O 7 撑杆跳成绩排序 10 O(_)O "); printf("n O(_)O 8 退出 O(_)O "); printf(" n (_)(_) (_) (_)(_) (_)(_) "); int reads(struct student stuN) / 读取运动员文件中的内容 FILE *fp; int i=0; if(fp=fopen("e: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.chenggantiao); fclose(fp); return i; void save(struct student stuN,int n) / 运动员信息改变后更新文件 FILE *fp; int i=0; if(fp=fopen("e:student.txt","w")=NULL) printf("文件打开失败!n"); return ; else 11 for(i=0;i<n;i+) fprintf(fp,"%s %s %f %f %fn",stui.num,stui.name,stui.baimi,stui.sanjitiao,stui.chenggantiao); fclose(fp); void add/*添加运动员信息*/ FILE *fp; int n,i; struct student stu; if(fp=fopen("e:student.txt","a")=NULL) /如果文件已经存在,可以追加学生信息 if(fp=fopen("e:student.txt","w")=NULL) / 文件不存在时,创建新文件,输入学生信息 printf("文件打开失败!n"); return; printf("请输入要添加的运动员数量,按回车键确认:"); scanf("%d",&n); for(i=1;i<=n;i+) printf("n请输入第%d个运动员的号码、姓名,用空格分开,并按回车键确认:n",i); 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); 12 fclose(fp); void show / 运动员信息显示函数 struct student stuN; int i,n; n=reads(stu); printf("*所有的学生信息如下*nn"); printf(" 序号 号码 姓名 百米赛跑 三级跳 撑杆跳 n"); printf("*n"); for(i=0;i<n;i+) printf("n%3d%12s%11s%11.2f%12.2f%11.2fn",i+1,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请输入要删除信息运动员号码,按回车键确认:"); scanf("%s",number); for(i=0;i<n;i+) if(strcmp(number,stui.num)=0) break; if(i>=n) printf("没有找到该运动员信息!n"); return; else 13 for(j=i+1;j<n;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;i+) if(strcmp(number,stui.num)=0) break; if(i>=n) printf("无此学生信息!"); 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;i<n-1;i+) for(j=0;j<n-1;j+) if(stuj.baimi<stuj+1.baimi)temp=stuj;stuj=stuj+1;stuj+1=temp; 14 save(stu,n); j=1 ; printf("*百米赛跑成绩排序结果如下*nn"); printf(" 名次 号码 姓名 百米赛跑 成绩 n"); printf("*n"); for(i=0;i<n;i+) / 输出结果并排名 if(stui.baimi=stui+1.baimi) printf("n%3d%12s%11s%11.2f%11.2f%11.2f%11.2fn",j,stui.num,stui.name,stui.baimi,stui.baimi); else printf("n%3d%12s%11s%11.2f%11.2f%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;i<n-1;i+) for(j=0;j<n-1;j+) if(stuj.sanjitiao<stuj+1.sanjitiao)temp=stuj;stuj=stuj+1;stuj+1=temp; save(stu,n); j=1 ; printf("*三级跳成绩排序结果如下*nn"); printf(" 名次 号码 姓名 三级跳 成绩 n"); printf("*15 *n"); for(i=0;i<n;i+) / 输出结果并排名 if(stui.sanjitiao=stui+1.sanjitiao) printf("n%3d%12s%11s%11.2f%11.2f%11.2f%11.2fn",j,stui.num,stui.name,stui.sanjitiao,stui.sanjitiao); else printf("n%3d%12s%11s%11.2f%11.2f%11.2f%11.2fn",j+,stui.num,stui.name,stui.sanjitiao,stui.sanjitiao); getch; void sheep / 按三级跳成绩排名 struct student stuN,temp; int i,j,n; n=reads(stu); for(i=0;i<n-1;i+) for(j=0;j<n-1;j+) if(stuj.chenggantiao<stuj+1.chenggantiao)temp=stuj;stuj=stuj+1;stuj+1=temp; save(stu,n); j=1 ; printf("*撑杆跳成绩排序结果如下*nn"); printf(" 名次 号码 姓名 三级跳 成绩 n"); printf("*n"); for(i=0;i<n;i+) / 输出结果并排名 if(stui.chenggantiao=stui+1.chenggantiao) 16 printf("n%3d%12s%11s%11.2f%11.2f%11.2f%11.2fn",j,stui.num,stui.name,stui.chenggantiao,stui.chenggantiao); else printf("n%3d%12s%11s%11.2f%11.2f%11.2f%11.2fn",j+,stui.num,stui.name,stui.chenggantiao,stui.chenggantiao); getch; 17