课程设计任务书题目:运动会成绩管理系统一、课程设计时间共计1周,20学时。
二、课程设计内容用C语言编写软件完成以下任务:1 录入运动员信息;2 按项目查询运动员成绩;3 按系排名(参照运动员的总成绩)。
三、课程设计要求1. 程序质量:✧贯彻结构化的程序设计思想。
✧用户界面友好,功能明确,操作方便。
✧用户界面中的菜单至少应包括“运动员信息录入”、“按项目查询运动员信息”、“按系排名”、“退出”4项。
✧代码应适当缩进,并给出必要的注释,以增强程序的可读性。
2. 课程设计说明书:课程结束后,上交课程设计说明书和源程序。
课程设计说明书的格式和内容参见提供的模板。
四、指导教师和学生签字指导教师:________ 学生签名:________五、说明书成绩沈阳航院设计用纸目录一、需求分析 ...................................... 错误!未定义书签。
二、程序流程图 .................................. 错误!未定义书签。
三、核心技术的实现说明及相应程序段.. 错误!未定义书签。
四、课设总结 ...................................... 错误!未定义书签。
五、参考文献 ...................................... 错误!未定义书签。
六、源程序 .......................................... 错误!未定义书签。
一、需求分析经过对程序设计题目的分析可知,整个程序的设计实现大致分为3个模块,每一个模块对应一个函数。
在这些函数当中,添加学生数据函数,按系排名(参照学生总成绩)函数,按项目查询学生成绩函数的实现严格按照题目的要求。
主函数及菜单函数控制程序的整体运行。
1. 添加学生数据函数主要实现程序最初运行时学生数据的录入以及其后的运行中学生数据的追加功能;2. 按系排名(参照学生总成绩)函数按照题目的具体要求实现的是参照不同院系的学生的总成绩给出院系的排名;3. 按项目查询函数允许按照项目名称对学生的各项成绩进行查询;除上面介绍的功能之外,程序还具有退出功能,可以在程序的一次运行当中循环执行所有的功能,并根据需要终止程序的执行。
每一个学生记录都包含学号、姓名、系别,以及赛跑比赛、跳远比赛、跳高比赛三门成绩,在程序当中,将学生记录类型定义为结构体类型,添加以及追加的学生信息直接写入定义的结构体中,其它函数每次对学生记录的访问,其数据来源都是该结构体,这样做不但可以保证学生数据的一致性,而且可以对学生数据进行永久保存,保证每次运行程序都可以采用原来的数据。
二、程序流程图1. 程序总体结构图图1程序总体结构图2. 具体功能框图(1)添加学生数据函数add图2 添加学生数据函数(2)按系排名(参照学生总成绩)函数sort图3按系别排名(3)按项目查询函数query三、核心技术的实现说明及相应程序段本程序主要由三个自定义函数和一个主函数组成,其中主函数以菜单的形式调用其它函数来实现要求的所有功能。
在这些函数当中,添加学生数据函数、按系排名函数和按项目查询函数是程序中较为核心的部分,下面分别进行说明。
1. 添加数据函数当执行学生成绩录入功能时,所录入的数据被储存程序开头所定义的结构体中,并且各种数据被保存其中,方便以后其他的功能函数调用。
具体的程序段如下:int n,i;printf("请输入要添加的学生数量,按回车键确认:");scanf("%d",&n);for(i=1;i<=n;i++){printf("\n请输入第%d个学生的学号、姓名,系别,用空格分开,并按回车键确认:\n",i);scanf("%s%s%s",stu[i].num,stu[i].name,stu[i].xibie);printf("\n请输入第%d个学生的赛跑比赛、跳远比赛、跳高比赛,用空格分开,并按回车键确认:\n",i);scanf("%f%f%f",&stu[i].race,&stu[i].jump,&stu[i].high);printf("%s %s %s %f %f %f \n",stu[i].num,stu[i].name,stu[i].xibie,stu[i].race,stu[i].jump,stu[i].high);}2. 按系排名函数(参照学生总成绩)对于按系的排名采用的排序算法是冒泡法排序,其中总成绩的求得是在排序的过程中实现的,整个排序过程在结构体数组stu中实现,由于排序算法涉及到两个数组元素的信息交换,因此还需要定义一个中间变量来协助。
排序函数使学生数据的排列顺序发生了变化,因此也需要对结构体进行更新。
此外,对于系别排序后名次的确定,仅在结果输出时予以显示。
具体的程序段如下:int i,j;printf("*********************按系成绩排序结果如下**********************************\n\n");printf(" 名次系别总成绩\n");printf("********************************************************** ***************\n");for(i=1;i<=N;i++)for(j=1;j<=N-i;j++){if(stu[j].race+stu[j].jump+stu[j].high<stu[j+1].race+stu[j+1].jump+stu[j+1].high ){temp=stu[j];stu[j]=stu[j+1];stu[j+1]=temp;}}for(i=1;i<=N;i++)printf("\n%d%12s%11.2f\n",i,stu[i].xibie,stu[i].race+stu[i].jump+stu[i].high );} 3.按项目进行运动员成绩查询当执行按项目进行运动员成绩查询时,整个查询过程是在结构体数组stu中实现的。
在此函数中,为了方便起见,用1代表赛跑比赛,2代表跳远比赛,3代表跳高比赛,输入数字后,用if语句进行判断,输出各个学生该项目的成绩。
具体的程序段如下:int i,a;printf("请输入1,2或3,1代表赛跑成绩,2代跳远成绩,3代表跳高成绩");scanf("%d",&a);if(a==1){printf("*********************按项目查询结果如下**********************************\n\n");printf(" 名次学号姓名系别赛跑\n");printf("************************************************* ************************\n");for(i=1;i<=N;i++){printf("\n%d%12s%12s%11s%11.2f\n",i,stu[i].num,stu[i].name,stu[i].xibie,stu[i].race);}getch();}if(a==2){printf("*********************按项目查询结果如下**********************************\n\n");printf(" 名次学号姓名系别跳远\n");printf("************************************************* ************************\n");for(i=1;i<=N;i++){ printf("\n%d%12s%11s%11s%11.2f\n",i,stu[i].num,stu[i]. name,stu[i].xibie,stu[i].jump);}getch();}if(a==3){printf("*********************按项目查询结果如下**********************************\n\n");printf(" 名次学号姓名系别跳高\n"); printf("************************************************* ************************\n");for(i=1;i<=N;i++){printf("\n%d%12s%11s%11s%11.2f\n",i,stu[i].num,stu[i].name,stu[i ].xibie,stu[i].high);}getch();}四、课设总结程序的编写基本上符合任务要求。
在本次计算机课程设计中,虽然遇到了不少的问题,但通过与王老师和同学的不断交流,问题还是慢慢地得到解决。
在这一周的时间里,我学会了更好地分析问题、解决问题,和与同学进行沟通,交换思想。
五、参考文献1 谭浩强.C程序设计.北京:清华大学出版社,20052 刘成等.C语言程序设计实验指导与习题集.北京:中国铁道出版社,2006六、源程序#include<stdio.h>#include<string.h>#include<stdlib.h>#include"conio.h"#define N 20struct student{char num[20];char name[10];char xibie[10];float race;float jump;float high;}stu[N],temp;void menu();void add();void sort();void query();void main(){int n;while(1){menu();printf("\n 请输入您要选择的操作序号,按回车键确认:");scanf("%d",&n);switch(n){case 1: add();break;case 2: sort();break;case 3: query();break;case 4: exit(0);default: printf("输入错误,请输入列表中存在的序号!\n ");}}}void menu(){printf(" ************************* 运动员成绩管理系统************************ ");printf("\n 1 添加学生数据");printf("\n 2 按系排名");printf("\n 3 按项目查询");printf("\n 4 退出");}void add()/*添加学生信息*/{int n,i;printf("请输入要添加的学生数量,按回车键确认:");scanf("%d",&n);for(i=1;i<=n;i++){printf("\n请输入第%d个学生的学号、姓名,系别,用空格分开,并按回车键确认:\n",i);scanf("%s%s%s",stu[i].num,stu[i].name,stu[i].xibie);printf("\n请输入第%d个学生的赛跑比赛、跳远比赛、跳高比赛,用空格分开,并按回车键确认:\n",i);scanf("%f%f%f",&stu[i].race,&stu[i].jump,&stu[i].high);printf("%s %s %s %f %f %f \n",stu[i].num,stu[i].name,stu[i].xibie,stu[i].race,stu[i].jump,stu[i].high);}}void sort(){int i,j;printf("*********************按系成绩排序结果如下**********************************\n\n");printf(" 名次系别总成绩\n");printf("******************************************************************** *****\n");for(i=1;i<=N;i++)for(j=1;j<=N-i;j++){if(stu[j].race+stu[j].jump+stu[j].high<stu[j+1].race+stu[j+1].jump+stu[j+1].high ){temp=stu[j];stu[j]=stu[j+1];stu[j+1]=temp;}}for(i=1;i<=N;i++)printf("\n%d%12s%11.2f\n",i,stu[i].xibie,stu[i].race+stu[i].jump+stu[i].high );}void query(){int i,a;printf("请输入1,2或3,1代表赛跑成绩,2代跳远成绩,3代表跳高成绩");scanf("%d",&a);if(a==1){printf("*********************按项目查询结果如下**********************************\n\n");printf(" 名次学号姓名系别赛跑\n");printf("******************************************************************** *****\n");for(i=1;i<=N;i++){printf("\n%d%12s%12s%11s%11.2f\n",i,stu[i].num,stu[i].name,stu[i].xibie,stu[i].race);}getch();}if(a==2){printf("*********************按项目查询结果如下**********************************\n\n");printf(" 名次学号姓名系别跳远\n");printf("******************************************************************** *****\n");for(i=1;i<=N;i++){printf("\n%d%12s%11s%11s%11.2f\n",i,stu[i].num,stu[i].name,stu[i].xibie,stu[i].jump);}getch();}if(a==3){printf("*********************按项目查询结果如下**********************************\n\n");printf(" 名次学号姓名系别跳高\n");printf("******************************************************************** *****\n");for(i=1;i<=N;i++){printf("\n%d%12s%11s%11s%11.2f\n",i,stu[i].num,stu[i].name,stu[i].xibie,stu[i].high);}getch();}}。