




下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、计算机科学与技术学院课程设计报告2015 201邑学年第二学期课程名称C 语言程序设计题 目学生成绩管理系统学生姓名XXX学 号 XXX专业班级XXX指导教师XXX合作者XXX2016年 6 月 30 日学生成绩管理系统本程序可实现对学生语数外三门课程成绩的录入与保存。1、 设计目的本程序旨在训练读者的基本编程能力,了解管理信息系统开发流程,熟悉C语言的各种语法、编写流程、以及能够熟练运用各种算法、以及各种函数的使用。2、 功能描述本程序可实现的功能:(1) 录入学生的成绩(2) 输出学生的成绩(3) 添加学生的成绩信息(4) 删除指定学生的成绩信息(5) 按照要求对学生成绩信息进行排序6)
2、根据学号查询指定学生的成绩( 7) 将学生的成绩信息以文件形式保存3、 总体设计具体实现main ()函数:程序首先调用 menu()函数,显示出系统主菜单,然后将 menu() 函数返回的从用户读取的选项k 值赋予k, 接着进入switch case 语句进入对应选项函数,若输入错误没有该选项则给出提示(default )以上过程为一个死循环,直到用户输入 0 为止。menu()函数:在屏幕上打印选项名称,然后用一个int类型的变量接受从用户输入的选项,最后将其return 至主函数。score *creatlink ()函数:创建链表主要实现流程如下:print()函数:先令P=head,
3、使p指向第一个节点,当 head=! NULL寸说明没有到链表尾端,那么就输出p 所指向的结构数据,然后让p 指向下一个节点,直到发现p=NULL为止。而当head=NUL加明链表中不存在数据,直接停止输出。score *add ()函数,添加新的学生信息,具体实现路程如流程图所示(图片制作时没有加Y/N 判断,在判断图框中均为向左为真,向右为假):score *search ()函数:用来查询学生成绩,传递给函数指向链表的头指针,查询时,如果找到与输入相匹配的学号则打印此学生,反之则输出“没有任何学生资料! ”:score *sortdata() 函数:该函数有学号、姓名、单科成绩排序(冒泡
4、排序法),实行过程如图:save ()函数:用来保存数据,首先从用户输入取得要保存的文件名,然后定义一个指向文件的指针,以读写方式打开文件。将写生信息依次存入文件。score *load() 函数:用于读取数据,通过“r+ ”方式打开文件并判断是否打开成功。具体实现如下:score *statistics() 函数:它能实现程序的统计,通过switch-case 语句选择统计方式,通过循环计算总分或者平均分并打印出来,流程都是通过循环,让指针逐个遍历整个链表,读取相应的数据并实现统计数据结构设计数据结构:定义了一个包含学生成绩信息的结构体(struct scorenode ),学 生信息包括学
5、号(number) 、姓名(name10) 、语文、数学、英语成绩(chinese 、mathmatic、 english ) 、 以及指向下一个结构体的链表指针(struct scorenode *next) 。函数功能描述main ()函数:主函数功能主要是让程序选择将要进行的操作,通过 menu()函数返 回的选项进入其他函数执行。int menu ( int k )函数:此函数显示主菜单内容,需要一个int 类型变量作为输入要执行的选项并返回给main ()函数。score *creatlink() 函数: 此函数用于创建链表,为了节省内存空间,我们采用malloc()函数为结构体分配
6、动态内存空间。另外考虑到学号不可能是0,所以用输入0 的方式来判断是否结束输入,将最后的结构体中的指针指向NULL, 并返回一个指向链表第一个结构的指针。void print ( score *head )函数:此函数返回值为空,知识为了在stdout 流(屏幕)上打印出学生的成绩信息,需要一个指向链表头的指针来逐个向后打印。score *add(score *head , score *stu) 函数:为学生信息中添加新的学生资料,然后重新排序(按学号),并返回头指针。传入函数的head为链表头指针,stu指针指的是 要添加的位置。score *search(score *head) 函数:
7、按照学号查找学生信息,需要链表头指针并返回指向被搜索学生的指针。搜索原理就是从头向后面依次检索。score *dele(score *head) 函数:删除指定学生的资料。传入头指针,在函数中创建变量储存要删除学生的学号,然后从头向尾检索,直至找到该学生并将其删除,返回头指 针。score *sortdata(score *head) 函数:用于按要求(学号、姓名、单科成绩)排序,最后返回头指针,排序运用老师上课时讲过的冒泡排序法。int save(score *p1) 函数:将链表内的数据以文件的形式储存,传入的p1 指针一开始指向链表头,随着储存顺序一个一个地向后面指,直到NULE止。函数
8、内部定义一个指向文件的指针*fp ,用于写入文件。score *load(score *head) 函数:读取文件数据,head 为一个新建的链表头指针,读取文件数据之后令其保存至新建的链表之中,并返回头指针。score *statistics(score *head) 函数: 统计成绩,可以统计总分、平均分、 最高 (低)分,返回操作后的链表首地址(头指针)。4、 程序实现源代码#include <>#include <>#include<>#include <>#define LEN sizeof(struct scorenode)#defi
9、ne DEBUG/*=数据结构=*/struct scorenodeint number;ft|%.1ft|%.1ft|n",p->number,p->name,p->chinese,p->mathmatic,p->english);printf("n");/* 打印表格域*/p=p->next; while (p!=NULL); /*=添加学生数据=*/* 函数 add, 功能:追加学生资料, 并且将所有学生资料按学号排序*/score *add(score *head,score *stu) score *p0,*p1,*p
10、2,*p3,*max; int i,j; float fen; char t10;p3=stu=(score *)malloc(LEN);/* 开辟一个新单元*/printf("n 输入要增加的学生的资料!");repeat4: printf(" 请输入学生学号(学号应大于0): ");scanf("%d",&stu->number);/* 输入学号,学号应大于0*/while(stu->number<0)getchar();printf(" 输入错误,请重新输入学生学号:");scanf
11、("%d",&stu->number);/* 输入错误,重新输入学号*/if(stu->number=0)goto end2;/* 当输入的学号为0 时,转到末尾,结束追加*/elsep3=head;if(n>0) for(i=0;i<n;i+) if(stu->number!=p3->number)p3=p3->next; elseprintf(" 学号重复, 请重输 !n");goto repeat4;/* 当输入的学号已经存在,程序报错,返回前面重新输入*/printf(" 输入学生姓名:
12、");scanf("%s",stu->name);/* 输入学生姓名 */printf(" 请输入语文成绩(0100) : ");scanf("%f",&stu->chinese);/* 输入语文成绩,成绩应在0-100*/while(stu->chinese<0|stu->chinese>100) getchar();printf(" 输入错误,请重新输入语文成绩");scanf("%f",&stu->chinese);/*输
13、入错误,重新输入语文成绩直到正确为止*/printf(" 请输入数学成绩(0100): ");scanf("%f",&stu->mathmatic);/* 输入数学成绩,成绩应在0-100*/while(stu->mathmatic<0|stu->mathmatic>100) getchar();printf(" 输入错误,请重新输入数学成绩");scanf("%f",&stu->mathmatic);/* 输入错误,*/printf(" 请输入英语成绩
14、(0100) : ");scanf("%f",&stu->english);/* 输入0-100*/while(stu->english<0|stu->english>100)getchar();printf(" 输入错误,请重新输入英语成绩");scanf("%f",&stu->english);重新输入英语成绩直到正确为止*/p1=head;p0=stu;if(head=NULL)head=p0;p0->next=NULL;资料 */else空 */if(p1-&
15、gt;next=NULL)链表的末尾*/p1->next=p0;p0->next=NULL;与新开单元相连接*/elsewhile(p1->next!=NULL)找到末尾,继续找*/p2=p1;p1=p1->next;p1->next=p0;p0->next=NULL;n=n+1;/* 输入错误,/* 当原来链表为空时,从首结点开始存放/* 链表不为/* 找到原来/* 将它/* 还没p1=head;p0=stu;for(i=1;i<n;i+)for(j=i+1;j<=n;j+)max=p1;p1=p1->next;if(max->nu
16、mber>p1->number)k=max->number;max->number=p1->number;p1->number=k;结点中的学号值,使得学号大者移到后面的结点中*/strcpy(t,max->name);strcpy(max->name,p1->name); strcpy(p1->name,t);前后结点中的姓名,使之与学号相匹配*/fen=max->chinese;max->chinese=p1->chinese; p1->chinese=fen;结点中的语文成绩,使之与学号相匹配*/fen=
17、max->mathmatic;max->mathmatic=p1->mathmatic; p1->mathmatic=fen;前后结点中的数学成绩,使之与学号相匹配*/fen=max->english;max->english=p1->english; p1->english=fen;前后结点中的英语成绩,使之与学号相匹配*/max=head;p1=head ;使max,p指向链表头*/ end2:printf(" 现在的学生数为:%d 个 !n",n);return(head);/*=查询数据=*/* 函数 search,
18、功能:查询学生成绩*/score *search(score *head)int number;score *p1,*p2;/* 交换前后/* 交换/* 交换前后/* 交换/* 交换/* 重新printf(" 输入要查询的学生的学号:");scanf("%d",&number);while(number!=0)if(head=NULL) printf("n 没有任何学生资料!n");return(head);printf("n");printf("| 学号 t| 姓名 t| 语文 t| 数学 t|
19、 英语 t|n");printf("n");p1=head;while(number!=p1->number&&p1->next!=NULL) p2=p1;p1=p1->next; if(number=p1->number) printf("|%dt|%st|%.1ft|%.1ft|%.1ft|n",p1->number,p1->name,p1->chinese,p1->mathmatic,p1->english);printf("n");elseprin
20、tf("%d 不存在此学生!n",number);printf(" 输入要查询的学生的学号,");scanf("%d",&number);printf(" 已经退出了!n");return(head);/*=删除数据=*/* 函数 dele ,功能:删除学生资料*/score *dele(score *head)score *p1,*p2;int number;printf(" 输入要删除的学生的学号( 输入 0 时退出 ):");scanf("%d",&nu
21、mber);getchar();while(number!=0)/*输入学号为0 时退出 */if(head=NULL)printf("n 没有任何学生资料!n");return(head);p1=head;while(number!=p1->number&&p1->next!=NULL)/*p1 指向的不是所要找*/p2=p1;p1=p1->next;if(number=p1->number)/*if(p1=head)head=p1->next;地二个结点地址赋予head*/elsep2->next=p1->nex
22、t;址 赋给前一结点地址*/printf(" 删除 :%dn",number);n=n-1;elseprintf("%d 不存在此学生!n",number);printf(" 输入要删除的学生的学号:");scanf("%d",&number);getchar();#ifdef DEBUGprintf(" 已经退出了!n");#endifprintf(" 现在的学生数为:%d 个 !n",n);return(head);/*=排序=*/* 定义排序函数。此函数带回一个
23、指向链表头的指针*/*p1 后移一个结点*/如果找到了*/* 若 p1 指向的是首结点,把/* 否则将下一个结点地/* 找不到该结点*/score *sortdata(score *head)score *p,*max;int i,j,x;float fen;char t10;if(head=NULL)printf("n 没有任何学生资料,请先建立链表!n");return(head);/* 链表为空*/max=p=head;for(i=0;i<80;i+)printf("*");printf("1按学生学号排序t2 按学生姓名排序t3
24、按语文成绩排序n");printf("4按数学成绩排序t5 按英语成绩排序tn");for(i=0;i<80;i+)printf("*");printf(" 请选择操作:");scanf("%d",&x);/* 选择操作 */getchar();switch(x)/* 用 switch 语句实现功能选择*/case 1 :for(i=1;i<n;i+)for(j=i+1;j<=n;j+)max=p;p=p->next; if(max->number>p->
25、number) k=max->number; max->number=p->number; p->number=k;*/* 交换前后结点中的学号值,使得学号大者移到后面的结点中strcpy(t,max->name); strcpy(max->name,p->name); strcpy(p->name,t);/* 交换前后结点中的姓名,使之与学号相匹配*/fen=max->chinese;max->chinese=p->chinese; p->chinese=fen;/* 交换前后结点中的语文成绩,使之与学号相匹配*/fen
26、=max->mathmatic;max->mathmatic=p->mathmatic; p->mathmatic=fen;/* 交换前后结点中的数学成绩,使之与学号相匹配*/fen=max->english;max->english=p->english; p->english=fen;/* 交换前后结点中的英语成绩,使之与学号相匹配*/ max=head; p=head;/*重新使max,p指向链表头*/ print(head); break;/* 打印值排序后的链表内容*/case 2 :for(i=1;i<n;i+)for(j=i+
27、1;j<=n;j+)max=p;p=p->next;if(strcmp(max->name,p->name)>0)/*strcmp :字符串比较函数*/strcpy(t,max->name);/*strcpy :字符串复制函数*/strcpy(max->name,p->name);strcpy(p->name,t);/* 交换前后结点中的姓名,使得姓名字符串的值大者移到后面的结点中*/k=max->number;max->number=p->number;p->number=k;/* 交换前后结点中的学号值,使之与姓
28、名相匹配*/fen=max->chinese;max->chinese=p->chinese; p->chinese=fen;/* 交换前后结点中的语文成绩,使之与姓名相匹配*/fen=max->mathmatic;max->mathmatic=p->mathmatic;p->mathmatic=fen;/* 交换前后结点中的数学成绩,使之与姓名相匹配*/fen=max->english;max->english=p->english; p->english=fen;/* 交换前后结点中的英语成绩,使之与姓名相匹配*/p=
29、head;max=head;print(head);break;case 3 : for(i=1;i<n;i+) for(j=i+1;j<=n;j+) max=p;p=p->next;if(max->chinese>p->chinese) fen=max->chinese;max->chinese=p->chinese; p->chinese=fen;/* 交换前后结点中的语文成绩,使得语文成绩高者移到后面的结点中*/k=max->number;max->number=p->number;p->number=k
30、;/* 交换前后结点中的学号,使之与语文成绩相匹配*/strcpy(t,max->name);strcpy(max->name,p->name);strcpy(p->name,t);/* 交换前后结点中的姓名,使之与语文成绩相匹配*/fen=max->mathmatic;max->mathmatic=p->mathmatic;p->mathmatic=fen;/* 交换前后结点中的数学成绩,使之与语文成绩相匹配*/fen=max->english;max->english=p->english; p->english=fe
31、n;/* 交换前后结点中的英语成绩,使之与语文成绩相匹配*/p=head;max=head;print(head);break;case 4 : for(i=1;i<n;i+) for(j=i+1;j<=n;j+) max=p;p=p->next;if(max->mathmatic>p->mathmatic)fen=max->mathmatic;max->mathmatic=p->mathmatic; p->mathmatic=fen;/* 交换前后结点中的数学成绩,使得数学成绩高者移到后面的结点中*/k=max->number
32、;max->number=p->number;p->number=k;/* 交换前后结点中的学号,使之与数学成绩相匹配*/ strcpy(t,max->name);strcpy(max->name,p->name);strcpy(p->name,t);/* 交换前后结点中的姓名,使之与数学成绩相匹配*/fen=max->chinese;max->chinese=p->chinese; p->chinese=fen;/* 交换前后结点中的语文成绩,使之与数学成绩相匹配*/fen=max->english;max->en
33、glish=p->english; p->english=fen;/* 交换前后结点中的英语成绩,使之与数学成绩相匹配*/p=head;max=head;print(head);break;case 5 :for(i=1;i<n;i+) for(j=i+1;j<=n;j+) max=p;p=p->next;if(max->english>p->english)fen=max->english;max->english=p->english; p->english=fen;/* 交换前后结点中的英语成绩,使得英语成绩高者移到
34、后面的结点中*/k=max->number;max->number=p->number;p->number=k;/* 交换前后结点中的学号,使之与英语成绩相匹配*/strcpy(t,max->name);strcpy(max->name,p->name);strcpy(p->name,t);/* 交换前后结点中的姓名,使之与英语成绩相匹配*/fen=max->chinese;max->chinese=p->chinese; p->chinese=fen;/* 交换前后结点中的语文成绩,使之与英语成绩相匹配*/fen=max
35、->mathmatic;max->mathmatic=p->mathmatic;p->mathmatic=fen;/* 交换前后结点中的数学成绩,使之与英语成绩相匹配*/p=head;max=head;print(head);break;default :printf(" 输入错误, 请重试 ! n");return (0);/*=保存数据=*/* 函数 save, 功能:保存学生的资料*/void save(score *p1)FILE *fp;char filepn20;/* 用来存放文件保存路径以及文件名*/printf(" 请输入文
36、件路径及文件名:");scanf("%s",filepn);if(fp=fopen(filepn,"w+")=NULL)printf(" 不能打开文件!n");exit(1);fprintf(fp,"学生成绩管理系统n");fprintf(fp,"n");fprintf(fp,"n");fprintf(fp,"| 学号 t| 姓名 t| 语文 t| 数学 t| 英语 t|n");fprintf(fp,"n");/* 打印表格域
37、*/while(p1!=NULL)fprintf(fp,"%dt%st%.1ft%.1ft%.1ftn",p1->number,p1->name,p1->chinese,p1->mathmatic,p1->english);p1=p1->next;/*下移一个结点*/fclose(fp);printf(" 文件已经保存!n");return ;/*=调入文件=*/* 函数 loadfile ,功能 : 从文件读入学生记录*/score *loadfile(score *head)score *p1,*p2;int m=
38、0;char filename10;FILE *fp;printf(" 请输入文件路径及文件名:");scanf("%s",filename);/* 输入文件路径及名称*/if(fp=fopen(filename,"r+")=NULL)printf(" 不能打开文件!n");return 0;fscanf(fp,"学生成绩管理系统n");fscanf(fp,"n");fscanf(fp,"n");fscanf(fp,"| 学号 t| 姓名 t|
39、语文 t| 数学 t| 英语 t|n");fscanf(fp,"n");/* 读入表格域*/printf("学生成绩管理系统n");printf("n");printf("n");printf("| 学号 t| 姓名 t| 语文 t| 数学 t| 英语 t|n");printf("n");/* 打印表格域*/m=m+1;if(m=1)p1=(score *)malloc(LEN);/*开辟一个新单元*/fscanf(fp,"%d%s%f%f%f"
40、,&p1->number,p1->name,&p1->chinese,&p1->mathmatic,&p1-> english);printf("|%dt|%st|%.1ft|%.1ft|%.1ft|n",p1->number,p1->name,p1->chinese,p1->mathmatic,p1->english);/* 文件读入与显示*/head=NULL;don=n+1;if(n=1) head=p1;else p2->next=p1;p2=p1;/*开辟一个新单元*
41、/p1=(score *)malloc(LEN);fscanf(fp,"%d%s%f%f%fn",&p1->number,p1->name,&p1->chinese,&p1->mathmatic,&p1 ->english);printf("|%dt|%st|%.1ft|%.1ft|%.1ft|n",p1->number,p1->name,p1->chinese,p 1->mathmatic,p1->english);/* 文件读入与显示*/while(!feof
42、(fp);p2->next=p1;p1->next=NULL;n=n+1;printf("n");/* 表格下线 */fclose(fp);/*结束读入,关闭文件 */return (head);/*=统计=*/* 函数 statistics, 功能:统计学生成绩*/score *statistics(score *head)float sum1=0,sum2=0,sum3=0,ave1=0,ave2=0,ave3=0,max=0,min=0;char maxname10,minname10;score *p;int x,y=0,i=0;p=head;print
43、f("1 个人总分和平均分t2 单科平均分t3 总分最高分和最低分n");scanf("%d",&x);getchar();switch(x)/*用 switch 语句实现功能选择*/case 1: if(head=NULL)printf("n 没有任何学生资料!n");return(head); elseprintf("n");printf("| 学号 t| 姓名 t| 语文 t| 数学 t| 英语 t| 总分 t| 平均分t|n");printf("-*/n");
44、/*while(p!=NULL)sum1=p->chinese+p->mathmatic+p->english; /* 计算个人总分*/ave1=sum1/3;/*计算个人平均分*/printf("|%dt|%st|%.1ft|%.1ft|%.1ft|%.1ft|%.1ft|n",p->number,p->nam e,p->chinese,p->mathmatic,p->english,sum1,ave1);/* 打印结果 */printf("n");p=p->next;return(head);br
45、eak;case 2: if(head=NULL)printf("n 没有任何学生资料!n");return(head);while(p!=NULL)sum1=sum1+p->chinese;sum2=sum2+p->mathmatic;sum3=sum3+p->english;/*计算总分*/y=y+1;ave1=sum1/y;ave2=sum2/y;ave3=sum3/y;/*计算平均分*/p=p->next;/* 使 p 指向下一个结点*/printf("语文平均分是%.1fn",ave1);printf("数学平
46、均分是%.1fn",ave2);printf("英语平均分是%.1fn",ave3);/*打印结果*/return(head);break;case 3:if(head=NULL)printf("n 没有任何学生资料!n");return(head);min=max=p->chinese+p->mathmatic+p->english;while(i<n)i=i+1;sum1=p->chinese+p->mathmatic+p->english; /*计算个人总分 */if(max<sum1)max=sum1;strcpy(maxname,p->name);if(min>sum1)min=sum1;strcpy(minname,p->name);p=p->next;printf(" 总分最高分:%.1f, 姓名:%s、 ",max,maxname);printf("n");printf(" 总分最低分:%.1f, 姓名:%s",min,minname);printf("n");return(head); break;default :printf(&
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 委托加工合同模板3篇
- 代理投票授权3篇
- 二手商业店买卖合同样本3篇
- 劳动合同解除决定通知协议决定3篇
- 户口迁移的严肃承诺3篇
- 保密性托管服务协议3篇
- 废品交易协议3篇
- 代为办理房产交易的委托书3篇
- 煤炭批发区域市场差异考核试卷
- 老年人辅助包装考核试卷
- 湖北省武汉市2025届高三下学期四月调研考试(二模)数学试题 含解析
- 高二下学期《家校携手凝共识齐心协力创辉煌》家长会
- 2025年人教版七年级下册英语全册教学设计
- 2024-2025学年人教版数学八年级下册期中检测卷(含答案)
- 电梯日常检查记录
- 教育的起源和古代东方文明古国的教育
- 有机化学6章对映异构-课件
- 抗菌药物使用强度(DDD)解析与控制
- T∕CACM 1064-2018 针刀医学临床 通用要求
- 招聘求职简历制作表格模板可编辑下载 精品简历模板 标准表格单页02
- 凑十法加法竖式运算(可打印)
评论
0/150
提交评论