C语言课程设计之校运动会管理系统的设计与实现_第1页
C语言课程设计之校运动会管理系统的设计与实现_第2页
C语言课程设计之校运动会管理系统的设计与实现_第3页
C语言课程设计之校运动会管理系统的设计与实现_第4页
C语言课程设计之校运动会管理系统的设计与实现_第5页
已阅读5页,还剩26页未读 继续免费阅读

下载本文档

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

文档简介

1、一 题目要求课题:校运动会管理系统的设计与实现具体要求:(1)信息初始化,依次输入: N参赛学校总数 M男子竞赛项目数 W女子竞赛项目总数 各项目名次取法有以下几种: 取前五名:第一名得分7分,第二名得分5分,第三名得分3分,第四名2分,第五名得分1分。 取前三名:第一名得分5分,第二名得分3分,第三名得分2分。 用户自定义:各名次权值由用户定义。(2)提醒用户填写比赛结果,输入各项目获奖运动员的信息。(3)所有信息记录完毕后,用户可以查询各个学校的比赛成绩,生成团体总分报表,查看参赛学校信息和比赛项目信息等。二 需求分析根据题目要求,将学校的信息和比赛项目等信息存放到指定的文件中,并能实现相

2、关信息的浏览功能,故在程序中应提供输入,输出,显示,查找,排序等操作。三 总体设计由需求分析可讲系统分为信息输入模块,比赛录入模块和查询模块三个模块,并追加一些辅助模块以增加程序的功能,方便使用。四 详细设计 1 主函数主要通过main()函数及choose()函数实现.void main() /*主函数*/ int choos printf(nn * * * 运动会分数统计 * * *nnn); printf(共有多少个学校参赛:); scanf(%d,&a); while(a20) if(a20) printf(n 参赛学校个数不能大于20nn); printf(共有多少个学校参赛:);

3、scanf(%d,&a); printf(有几个男子组:); scanf(%d,&c); printf(有几个女子组:); scanf(%d,&d); for(i=0;i=a;i+) fi=(struct node *)malloc(sizeof(struct node)*(c+d+3); for(j=0;j=c+d+2;j+) fij.num=0; choos=choose(); while(1) while(choos8) choos=choose(); (*gchoos)(); printf(n); choos=choose(); int choose() int choo; print

4、f(nn 1*输入成绩n);printf( 2*统计各学校的总分n); printf( 3*按学校编号排序输出n); printf( 4*按学校总分排序输出n); printf( 5*按男团体总分排序输出n); printf( 6*按女团体总分排序输出n); printf( 7*按学校编号查询学校某个项目的成绩n); printf( 8*按项目编号查询取得前三或前五名的学校n); printf( 9*退出nn); printf(请选择:); scanf(%d,&choo); 2 成绩输入结束输入运动项目代号输入评分制度依次输入获奖学校开始是否在范围是否为三或五图2 运动会成绩输入流程图当选择1

5、 时进行成绩的输入.实现的功能函数为input(),相关实现如下: void input() int ab,ac,ae,af,g=1,get5=0,0,0,0,0; printf(n请输入项目代号:); ale:scanf(%d,&ab); if(abc+d|ab1) printf(n此项目代号不存在,重新输入n); goto ale; ae=0; for(i=0;i=a;i+) if(fiab.num!=0) ae=1; break; if(ae=1) al2: printf(n此项目成绩曾经已被录入过,是否要重新录入(您输入的项目代号可能有误,强烈建议您查证后再录入):n); printf

6、( 1+重新录入(若重新录入,以前的该项目成绩将被删除)n); printf( 2+不要,待查证后再录入nn); scanf(%d,&af); if(af=2) printf(您已取消录入!n); return; else if(af=1) for(i=1;i=a;i+) if(fiab.num!=0) fi0.num=fi0.num-fiab.num; if(ab=c) fic+d+1.num=fic+d+1.num-fiab.num; else fic+d+2.num=fic+d+2.num-fiab.num; fiab.num=0; else goto al2; al: printf(n

7、此项目是以前几名为胜出者:nn); printf( 3-以前三名n); printf( 5-以前五名nn); scanf(%d,&ac); if(ac=3) printf(n请依次输入获胜学校代号:); af=5; for(i=0;ia|ae1) printf(%d学校代号不存在,重新输入第%d名的学校代号n,ae,g); goto alq; for(b=0;b5;b+) if(ae=getb) printf(同一个学校不能在同一项目中有两个名次,请重新输入第%d名的学校代号!n,g); goto alq; else getb=ae; fae0.num=fae0.num+af; faeab.n

8、um=af; if(ab3) af=af-2; else af-; g+; else if(ac=5) printf(请依次输入获胜学校代号:); af=7; for(i=0;ia|ae1) printf(%d学校代号不存在,重新输入第%d名的学校代号n,ae,g); goto alw; for(b=0;b5;b+) if(ae=getb) printf(同一个学校不能在同一项目中有两个名次,请重新输入第%d名的学校代号!n,g); goto alw; else getb=ae; fae0.num=fae0.num+af; faeab.num=af; if(ab3) af=af-2; else

9、 af-; g+; else goto al; printf(nn 输入完成 ! ! ! ! n); 3 成绩统计当选择2 时进行成绩的输入.实现的功能函数为each (),相关实现如下:void each() printf(n 对应的格式为:n 学校代号:团体总成绩nn ); for(i=1;i=a;i+) printf(%2d:%3d ,i,fi0.num); if(i%3=0) printf(n ); 4 按照各种方式输出 主要有按学校编号输出,按学校总分输出,按男团输出,按女团输出.相关实现分别如下:void biaohao() printf(n项目代号 ); for(i=1;i9)

10、printf(%4d ,i); else printf(%5d ,i); printf(n); printf(学校代号 n); for(i=1;i=a;i+) printf( %d ,i); for(b=1;b9) printf(%4d,fib.num); else printf(%5d,fib.num); printf(n); void zongfen() struct nod int ke; int num; ; int ha; struct nod *de; de=(struct nod *)malloc(sizeof(struct nod)*a+1);printf(n 按学校编号排序输

11、出nn); printf( 学校代号 总分nn); for(i=1;i=a;i+) dei.ke=i; dei.num=fi0.num; for(i=1;i=a;i+) for(b=i;bdei.num) ha=deb.ke; deb.ke=dei.ke; dei.ke=ha; ha=deb.num; deb.num=dei.num; dei.num=ha; for(i=1;i=a;i+) printf(%13d%8dn,dei.ke,dei.num); void nanzong() struct nod int ke; int num; ; int ha; struct nod *de; d

12、e=(struct nod *)malloc(sizeof(struct nod)*a+1); printf(n 按男子团体总分排序输出nn); printf( 学校代号 男子团体总分nn); for(i=1;i=a;i+) dei.ke=i; dei.num=fic+d+1.num; for(i=1;i=a;i+) for(b=i;bdei.num) ha=deb.ke; deb.ke=dei.ke; dei.ke=ha; ha=deb.num; deb.num=dei.num; dei.num=ha; for(i=1;i=a;i+) printf(%13d%12dn,dei.ke,dei.

13、num); void nvzong() struct nod int ke; int num; ; int ha; struct nod *de; de=(struct nod *)malloc(sizeof(struct nod)*a+1); printf( 按女子团体总分排序输出nn); printf( 学校代号 女子团体总分nn); for(i=1;i=a;i+) dei.ke=i; dei.num=fic+d+2.num; for(i=1;i=a;i+) for(b=i;bdei.num) ha=deb.ke; deb.ke=dei.ke; dei.ke=ha; ha=deb.num;

14、 deb.num=dei.num; dei.num=ha; for(i=1;ia|drc+d|dta|drc+d|dtc+d|ge1) printf(没有此项目代号,重新输入n); goto all; for(i=1;i=a;i+) if(fbge.num=2) sedy=1; if(sedy=0) printf(此项目没有录入成绩n); return; for(i=1;i0;i-) for(b=1;b=a;b+) if(fbge.num=i) printf(%5d,b); 6 保存退出void exit0() FILE *fp; int k; alp:if(fp=fopen(sore.txt

15、,w)=NULL) printf(创建文件失败n); printf( 1*重试n); printf( 2*强制退出(数据将不会保存到文件)n); printf( 3*回到主菜单n); alj: scanf(%d,&k); if(k=1) goto alp; else if(k=2) exit(0); else if(k=3) return; else printf(输入错误,请重新输入:); goto alj; fprintf(fp,nn); fprintf(fp,运动会分数统计表nnn); fprintf(fp,项目代号); for(i=1;i=c+d;i+) fprintf(fp,%5d,

16、i); fprintf(fp, ); fprintf(fp,n 学校代号n); for(i=1;i=a;i+) fprintf(fp,%10d,i); for(b=1;b=c+d;b+) fprintf(fp,%5d,fib.num); fprintf(fp,n); fprintf(fp,nn); fprintf(fp, 注:本次运动会有%d个学校参赛nn,a); fprintf(fp, 其中1 %d组是男子组,%d %d组是女子组n,c,c+1,c+d); printf(n比赛成绩已保存到当前路径下的sore.txt文件中nn); fclose(fp); exit(1); 五 原程序代码#i

17、nclude #include #include #includeint a,b,c,d,i,j; struct node int num; ; struct node *f22; void exit0() /*保存退出*/ FILE *fp; int k; alp:if(fp=fopen(sore.txt,w)=NULL) printf(创建文件失败n); printf( 1*重试n); printf( 2*强制退出(数据将不会保存到文件)n); printf( 3*回到主菜单n); alj: scanf(%d,&k); if(k=1) goto alp; else if(k=2) exit

18、(0); else if(k=3) return; else printf(输入错误,请重新输入:); goto alj; fprintf(fp,nn); fprintf(fp,*运动会分数统计表*nn);fprintf(fp,*统计者:可输入个人姓名);fprintf(fp,项目代号 ); for(i=1;i=c+d;i+) fprintf(fp, %d,i); fprintf(fp, ); fprintf(fp,n学校代号n); for(i=1;i=a;i+) fprintf(fp,%10d,i); for(b=1;bc+d|ab1) printf(n此项目代号不存在,重新输入n); go

19、to ale; ae=0; for(i=0;i=a;i+) if(fiab.num!=0) ae=1; break; if(ae=1) al2: printf(n此项目成绩曾经已被录入过,是否要重新录入(您输入的项目代号可能有误,强烈建议您查证后再录入):n); printf( 1+重新录入(若重新录入,以前的该项目成绩将被删除)n); printf( 2+不要,待查证后再录入nn); scanf(%d,&af); if(af=2) printf(您已取消录入!n); return; else if(af=1) for(i=1;i=a;i+) if(fiab.num!=0) fi0.num=f

20、i0.num-fiab.num; if(ab=c) fic+d+1.num=fic+d+1.num-fiab.num; else fic+d+2.num=fic+d+2.num-fiab.num; fiab.num=0; else goto al2; al: printf(n此项目是以前几名为胜出者:nn); printf( 3-以前三名n); printf( 5-以前五名nn); scanf(%d,&ac); if(ac=3) printf(n请依次输入获胜学校代号:); af=5; for(i=0;ia|ae1) printf(%d学校代号不存在,重新输入第%d名的学校代号n,ae,g);

21、 goto alq; for(b=0;b5;b+) if(ae=getb) printf(同一个学校不能在同一项目中有两个名次,请重新输入第%d名的学校代号!n,g); goto alq; else getb=ae; fae0.num=fae0.num+af; faeab.num=af; if(ab3) af=af-2; else af-; g+; else if(ac=5) printf(请依次输入获胜学校代号:); af=7; for(i=0;ia|ae1) printf(%d学校代号不存在,重新输入第%d名的学校代号n,ae,g); goto alw; for(b=0;b5;b+) if

22、(ae=getb) printf(同一个学校不能在同一项目中有两个名次,请重新输入第%d名的学校代号!n,g); goto alw; else getb=ae; fae0.num=fae0.num+af; faeab.num=af; if(ab3) af=af-2; else af-; g+; else goto al; printf(nn 输入完成 ! ! ! ! n); void each() /*输出各个学校的成绩*/ printf(n 对应的格式为:n 学校代号:团体总成绩nn ); for(i=1;i=a;i+) printf(%2d:%3d ,i,fi0.num); if(i%3=

23、0) printf(n ); void biaohao() printf(n项目代号 ); for(i=1;i9) printf(%4d ,i); else printf(%5d ,i); printf(n); printf(学校代号 n); for(i=1;i=a;i+) printf( %d ,i); for(b=1;b9) printf(%4d,fib.num); else printf(%5d,fib.num); printf(n); void zongfen() /*按学校编号顺序输出成绩*/ struct nod int ke; int num; ; int ha; struct

24、nod *de; de=(struct nod *)malloc(sizeof(struct nod)*a+1);printf(n 按学校编号排序输出nn); printf( 学校代号 总分nn); for(i=1;i=a;i+) dei.ke=i; dei.num=fi0.num; for(i=1;i=a;i+) for(b=i;bdei.num) ha=deb.ke; deb.ke=dei.ke; dei.ke=ha; ha=deb.num; deb.num=dei.num; dei.num=ha; for(i=1;i=a;i+) printf(%13d%8dn,dei.ke,dei.num); void nanzong() /*按男子团体总成绩排名输出*/ struct nod int ke; int num; ; int ha; struct nod *de; de=(struct nod *)malloc(sizeof(struct nod)*a+1); printf(n 按男子团体总分排序输出nn); printf( 学校代号 男子团体总分nn); for(i=1;i=a;i+) dei.ke=i; dei.num=fic+d+1.num; for(i=1;i=a;i+) for(b=i;bdei.num) ha=deb.ke; deb.ke=dei.ke; de

温馨提示

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

评论

0/150

提交评论