版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、c+学生成绩管理系统的设计与实现学生成绩管理系统的设计与实现一、题目学生成绩管理系统的设计与实现二、内容1、每一条记录包括一个学生的学号、姓名、3门成绩、平均成绩。powered by 2、输入功能:可以一次完成无数条记录的输入。3、显示功能:完成全部学生记录的显示。4、查找功能:完成按姓名查找学生记录,并显示。5、排序功能:按学生平均成绩进行排序。6、插入功能:按平均成绩高低插入一条学生记录。7、保存功能:将学生记录保存在任何自定义的文件中,如保存在:c:score。8、读取功能:将保存在文件中的学生记录读取出来。9、有一个清晰美观界面来调用各个功能三、要求1、整个系统均用C语言实现;2、利
2、用指针、链表来实现学生成绩的数据结构设计;3、系统具有输入、显示、查询、删除、排序、插入,保存、读取基本功能;4、系统的各个功能模块都用函数的形式来实现;5、可以将学生成绩信息保存在文件中。6、可以将学生信息从文件中读取出来。四、内容整个系统除了主函数外,另外还有10个函数,实现八大功能:输入功能、显示功能、查找功能、排序功能、插入功能、保存功能、读取功能。各个函数的详细设计说明分别如下:1、 主函数 main()利用无限次循环for(;)和swithch()实现各函数的调用,系统根据输入的数字选项来调用相应的函数。2、 &
3、#160; 初始化函数 STUDENT *init()这是一个无参函数,里面只有一个语句,它的作用是使链表初始化,使head的值为NULL。比如:没有这个函数的话,在你没有输入任何数据的情况下,去执行显示功能的时候会显示一些乱码!3、 菜单选择函数 int menu_select();这是一个无参函数,主要实现“功能选择”的界面,在这个界面里有显
4、示系统的九大功能,根据每个功能前面的序号进行选择,中间还显示系统当前的时间。等执行完每一个函数功能后,按任一键回到主界面也要通过这个函数来实现!4、 输入记录函数 STUDENT *create()这是一个无参函数,用来执行第学生成绩记录的输入,当学生为0时停止输入,函数结束后,带回一个指向链表头的指针head。算法:先声明一个首节点head,并将head->next设为NULL。每输入一个数据就声明一个新节点p,把p->next设为NUL
5、L,并且链接到之前列表的尾端。5、 显示记录函数 void print(STUDENT *head)这是一个不返回值的有参函数,形参为“链表头的指针”,负责对全部学生成绩记录的输出,不足之处就是不能对学生成绩进行分页显示。算法:先将p结点的指针指向第一个结点,将p结点(即第一个结点)的数据输出。然后再将p结点的指针指向p指针的的指针(即下一结点),将p结点(即第一结点)的数据输出。重复执行此步聚直到p指针指向NULL为止。6、 &
6、#160; 查找记录函数 void search(STUDENT *head)这是一个不返回值的有参函数,形参为“链表头的指针”,实现按学号对某个学生进行查找,并显示所查找到的记录。算法:采用线性查找法往下一个节点查找。输入所要查找的学生的学号s,设一个指针变量p,先指向第一个结点,当strcmp(p->name,s) && p != NULL时,使p后移一个结点,如果p!=NULL,输出p所指的结点7、 &
7、#160; 删除记录函数 STUDENT *delete(STUDENT *head)powered by 这是一个有参函数,形参为“链表头的指针”,先输入要删除的学生记录的学号,找到后显示该学生信息,等确认后便可按“Y”进行删除。算法:从p指向的第一个结点开始,检查该结点中的num值是否等于输入的要求删除的那个学号。如果相等就将该结点删除,如不相等,就将p后移一个结点,再如此进行下去,直到遇到表尾为止。8、排序函数 STUDENT *sort(STUDENT *head)这是一个有参函数,形参为“链表头的指针”,按学生成
8、绩的平均分高低进行排序,还可以显示名次。9、 插入函数 STUDENT *insert(STUDENT *head,STUDENT *new)这是一个有参函数,形参有两个,一个是“链表头的指针”,一个是“待插入指针”,按照原来成绩平均分的高低进行插入,插入后会重新进行排序,并返回。算法:先将学生的成绩按平均分由高分到低分进行排序,再插入一个新生的结点,要求按平均分的高低顺序插入。先用指针变量p0指向待插入的结点,p1指向第一个结点。如果p0->a
9、verage<p1->average,则待插入的结点不应插在p1所指的结点之前。此时将p1后移,并使p2指向刚才p1所指的结点。重复以上的步骤,直到p0->average>=p1->average为止。这时将p0指向的结点插到p1所指结点之前。但是如果p1所指的已是表尾结点,则p1就不应后移了。如果p0->average比所有结点的average都小,则应将p0所指的结点插到链表末尾。如果插入的位置既不在第一个结点之前,又不在表尾结点之后,则将p0的值赋给p2->,使p2->next指向待插入的结点,然后将p1的值赋给p0->next,使得
10、p0->next指向p1指向的变量。如果插入位置为第一个结点之前,则将p0赋给head,将p1赋给p0->next。如果要插到表尾之后,应将p0赋给p1->next,NULL赋给p0->next。最后再调用排序的函数,将学生成绩重新排序.10、保存数据到文件函数 void save(STUDENT *head)这是一个不返回值的有参函数,形参为“链表头的指针”,可以把学生记录保存在电脑上由自己任意命名的二进制文件。11、从文件读数据函数 STUDENT *load()这是一个不返回值的有参函数,形参为“链表头的指针”,根据输入的文件地址进行读取。五、调试分析(1)刚开始
11、没有那个初始化函数,程序运行后,没有输入任何数据就试得去执行显示功能,结果显示的是一些乱码!加入初始化函数后,这种现象也随之消失。(2)刚开始执行输入函数,按学号顺序输入十个学生的成绩,输完后执行显示功能,学生成绩记录是按学号的反顺序显示的,试着在其中增加一些语句,希望能把学号按正常顺序显示,但暂时没有成功,所以在输入成绩时只能按学号反顺序输入,最后就按学号正常顺序输出了。(3)刚开始时,先把成绩按平均分排序,再插入一个学生的成绩,执行显示功能,虽然插入的学生的成绩能正常插入,但该学生的名次为0。后来,在插入成绩之后,调用排序函数,把所有成绩重新排序一次。(4)在输入函数中设了一个无限循环,可
12、以输入无数个学生的成绩信息,当学号为0的时候则停止输入。(5)输入太多个学生的成绩时,屏幕显示不能控制为一页一页显示,所以为了方便起见,不要输入太多记录,十七左右为最佳。(6)在没有输入任何信息的情况下,去执行排序功能,最后显示有一个记录,学号、姓名为空白,成绩都为0,名次为1。(7)在输入选项时不能输入字母,否则会死循环,建议不要乱输字母。六、总结经过一个多星期的C语言课程设计,感觉自己收获不少!首先是:链表本来上课是没有上的,但这个课程设计里面主要都是用链表,因为要达到这样的功能,使用链表相当方便,但不容易理解,所以在这方面我很了很多的时间看课本和参考课外书,使C语言的知识强化了不少。其次
13、,在做课程设计的过程中,发现了平时很多没有注意到的问题,例如:返回值函数和不返回值函数两者在主函数中的调用是不同的更重要的是,这次课程设计虽然花了我不少时间,但正是这些时间,让我见识到了C语言的重要性。这个学生成绩管理系统都是在自己知识范围内完成的,所以界面清晰简单,可能不是很好看,但绝对实用!从这里我也得到一个体会,做一个程序,或者开发一个软件,应该着重从它的后台制作入手,不能做出一个中看不中用的程序或者软件。相信这次的课程设计为我以后继续从事计算机工作打了一个小小的开头。由于这是第一次进行设计,写文档,难免会写得不好!学生成绩管理系统/*头文件*/#include <stdio.h&
14、gt;#include<dos.h>#include<stdlib.h> /*其它说明*/powered by #include<string.h> /*字符串函数*/#include<mem.h> /*内存操作函数*/#include<ctype.h> /*字符操作函数*/#include<
15、alloc.h> /*动态地址分配函数*/#define LEN sizeof(STUDENT)typedef struct stu /*定义结构体数组用于缓存数据*/char num6;char name5;int score3;int sum;float average;int order;struct stu *next;STUDENT;/*函数原型*/STUDENT *init();
16、0; /*初始化函数 by */int menu_select(); /*菜单函数*/STUDENT *create(); /*创建链表*/void print(STUDENT *head); /* 显示全部记录*/void search(STUDENT *head); /*查找记录*/STUDENT *delete(STUDENT *head);
17、; /*删除记录*/STUDENT *sort(STUDENT *head); /*排序*/STUDENT *insert(STUDENT *head,STUDENT *new); /*插入记录*/void save(STUDENT *head); /*保存文件*/STUDENT *load(); /*读文件*
18、/*主函数界面*/main()STUDENT *head,new;head=init(); /*链表初始化,使head的值为NULL*/for(;) /*循环无限次*/ switch(menu_select()
19、60; case 1:head=create();break; case 2:print(head);break; case 3:search(head);break;
20、; case 4:head=delete(head);break; case 5:head=sort(head);break; case 6:head=insert(head,&new);break; /*&new表示返回地址*/ case 7:save(head);break; case 8:head=load(); break; case 9:exit(0);&
21、#160; /*如菜单返回值为9则程序结束*/ /*初始化函数*/STUDENT *init()return NULL; /*返回空指针*/*菜单选择函数*/menu_select()int n;struct date d; /*定义时间结构体*/getdate(&
22、d); /*读取系统日期并把它放到结构体d中*/printf("press any key to enter the menu."); /*按任一键进入主菜单*/getch(); /*从键盘读取一个字符,但不显示于屏幕*/clrscr(); /*清屏*/printf("*n");printf("tt
23、; Welcome ton");printf("ntt The student score manage systemn");printf("*MENU*n");printf("ttt1. Enter the recordn");
24、 /*输入学生成绩记录*/printf("ttt2. Print the recordn"); /*显示*/printf("ttt3. Search record on namen"); &
25、#160; /*寻找*/printf("ttt4. Delete a recordn"); /*删除*/printf("ttt5. Sort to make new a filen"); /*排序*/printf("ttt6. Insert record to listn");
26、; /*插入*/printf("ttt7. Save the filen"); /*保存*/printf("ttt8. Load the filen");
27、; /*读取*/printf("ttt9. Quitn"); /*退出*/printf("ntt
28、60; Made by Hu Haihong.n");printf("*n");printf("tttt%d%d%dn",d.da_year,d.da_mon,d.da_day); /*显示当前系统日期*/do printf("ntttEnter your choice(19):"); scanf("%
29、d",&n); while(n<1|n>9); /*如果选择项不在19之间则重输*/ return(n); /*返回选择项,主函数根据该数调用相应的函数*/*输入函数*/STUDENT *create()int i,s;STUDENT *head=NULL,*p;
30、60; /* 定义函数.此函数带回一个指向链表头的指针*/clrscr();for(;) p=(STUDENT *)malloc(LEN); /*开辟一个新的单元*/ if(!p) /*如果指针p为空*/ printf("nOut of memory.");
31、; /*输出内存溢出*/ return (head); /*返回头指针,下同*/ printf("Enter the num(0:list end):"); scanf("%s",p->nu
32、m); if(p->num0='0') break; /*如果学号首字符为0则结束输入*/ printf("Enter the name:"); scanf("%s",p->name); printf("Please en
33、ter the %d scoresn",3); /*提示开始输入成绩*/ s=0; /*计算每个学生的总分,初值为0*/ for(i=0;i<3;i+) /*3门课
34、程循环3次*/ do printf("score%d:",i+1); scanf("%d",&p->scorei); if(p->scorei<0 | p->scorei>100)
35、160; /*确保成绩在0100之间*/ printf("Data error,please enter again.n"); while(p->scorei<0 | p->scorei>100); s=s+p->scorei; /*累加各门成绩*/
36、; p->sum=s; /*将总分保存*/ p->average=(float)s/3; /*先用强制类型转换将s转换成float型,再求平均值*/ p->order=0; &
37、#160; /*未排序前此值为0*/ p->next=head; /*将头结点做为新输入结点的后继结点*/ head=p;
38、160; /*新输入结点为新的头结点*/ return(head); /* 显示全部记录函数*/void print(STUDENT *head)int i=0; /* 统计记录条数*/STUDENT *p; /*移动指针*/clrscr(
39、);p=head; /*初值为头指针*/printf("n*STUDENT*n");printf("-n");printf("| Rec | Num | Name | Sc1 |
40、 Sc2 | Sc3 | Sum | Ave | Order |n");printf("-n");while(p!=NULL) i+; &
41、#160; printf("| %3d | %4s | %-4s | %3d | %3d | %3d | %3d
42、; | %4.2f | %-5d|n", i, p->num,p->name,p->score0,p->score1,p->score2,p->sum,p->average,p->order); p=p->next; printf("-n"
43、;);printf("*END*n");/*查找记录函数*/void search(STUDENT *head)STUDENT *p; /* 移动指针*/char s5; /*存放姓名用的字符数组*/clrscr();printf("Please enter name for searching.n");scanf("%s",s);p=head;
44、 /*将头指针赋给p*/while(strcmp(p->name,s) && p != NULL) /*当记录的姓名不是要找的,或指针不为空时*/ p=p->next; /*移动指针,指向下一结点*/ if(p!=NULL)
45、 /*如果指针不为空*/ printf("n*FOUND*n"); printf("-n"); printf("| Num | Name
46、60; | sc1 | sc2 | sc3 | Sum | Ave | Order |n"); printf("-n&quo
47、t;); printf("| %4s | %4s | %3d | %3d | %3d &
48、#160; | %3d | %4.2f | %-5d|n", p->num,p->name,p->score0,p->score1,p->score2,p->sum,p->average,p->order); printf("-n&
49、quot;); printf("*END*n"); else printf("nThere is no num %s student on the list.n",s); /*显示没有该学生*/*删除记录函数*/STUDENT *delete(STUDENT *head
50、)int n;STUDENT *p1,*p2; /*p1为查找到要删除的结点指针,p2为其前驱指针*/char c,s6; /*s6用来存放学号,c用来输入字母*/clrscr();printf("Please enter the deleted num: ");scanf("%s",s);p1=p2=head; /*给p1和p2赋初值头指针*/while(strcmp(p1->nu
51、m,s) && p1 != NULL) /*当记录的学号不是要找的,或指针不为空时*/ p2=p1; /*将p1指针值赋给p2作为p1的前驱指针*/ p1=p1->next; /*将
52、p1指针指向下一条记录*/ if(strcmp(p1->num,s)=0) /*学号找到了*/ printf("*FOUND*n"); printf("-n"); printf("| Num
53、60; | Name | sc1 | sc2 | sc3 | Sum | Ave
54、160; | Order |n"); printf("-n"); printf("| %4s | %4s | %3d |
55、0; %3d | %3d | %3d | %4.2f | %-5d|n", p1->num,p1->name,p1->score0,p1->score1,p1->score2,p1->
56、;sum,p1->average,p1->order); printf("-n"); printf("*END*n"); printf("Are you sure to delete the student Y/N ?"); /*提示是否要删除,输入Y删除,N则退出*/ for(;)
57、160; scanf("%c",&c); if(c='n'|c='N') break; /*如果不删除,则跳出本循环*/ if(c='y'|c='Y')
58、0; if(p1=head) /*若p1=head,说明被删结点是首结点*/ head=p1->next;
59、60; /*把第二个结点地址赋予head*/ else p2->next=p1->next; /*否则将一下结点地址赋给前一结点地址*/ n=n-1;
60、60; printf("nNum %s student have been deleted.n",s); printf("Don't forget to save.n");break; /*删除后就跳出循环*/
61、60; else printf("nThere is no num %s student on the list.n",s); /*找不到该结点*/return(head);/*排序函数*/STUDENT *sort(STUDENT *head)int i=0;
62、 /*保存名次*/STUDENT *p1,*p2,*t,*temp; /*定义临时指针*/temp=head->next;
63、160; /*将原表的头指针所指的下一个结点作头指针*/head->next=NULL; /*第一个结点为新表的头结点*/while(temp!=NULL)
64、60; /*当原表不为空时,进行排序*/ t=temp; /*取原表的头结点*/ temp=temp->next; /*原表头结点指针后移*/
65、60; p1=head; /*设定移动指针p1,从头指针开始*/ p2=head; /*设定移动指针p2做为p1的前驱,初值为头指针*/
66、0; while(t->average<p1->average&&p1!=NULL) /*作成绩平均分比较*/ p2=p1; /*待排序点值小,则新表指针后移*/
67、60; p1=p1->next; if(p1=p2) /*p1=p2,说明待排序点值大,应排在首位*/ t->nex
68、t=p1; /*待排序点的后继为p*/ head=t; /*新头结点为待排序点*/ else
69、/*待排序点应插入在中间某个位置p2和p1之间,如p为空则是尾部*/ t->next=p1; /*t的后继是p1*/ p2->next=t; /*p2的后继是t*/ &
70、#160; p1=head; /*已排好序的头指针赋给p1,准备填写名次*/while(p1!=NULL) /*当p1不为空时,进行下列操作*/ i+;
71、 /*结点序号*/ p1->order=i; /*将结点序号赋值给名次*/ p1=p1->next; /*指针后移*/ printf("Sorting is sucessful.n");
72、; /*排序成功*/return (head);/*插入记录函数*/STUDENT *insert(STUDENT *head,STUDENT *new)STUDENT *p0,*p1,*p2;int n,sum1,i;p1=head; /*使p1指向第一个结点*/p0=new; /*p0指向要插入的结点*/printf("nPlease enter a new record.n");
73、 /*提示输入记录信息*/printf("Enter the num:");scanf("%s",new->num);printf("Enter the name:");scanf("%s",new->name);printf("Please enter the %d scores.n",3);sum1=0; /*保存新记录的总分,初值为0*/for(i=0;i<3;i+
74、) do printf("score%d:",i+1); scanf("%d",&new->scorei); if(new->scorei&g
75、t;100|new->scorei<0) printf("Data error,please enter again.n"); while(new->scorei>100|new->scorei<0); sum1=sum1+new->scorei; &
76、#160; /*累加各门成绩*/ new->sum=sum1; /*将总分存入新记录中*/new->average=(float)sum1/3;new->order=0;if(head=NULL) /*原来的链表是空表*/ head=p0;p0->next=NULL; /*使p0指向的结点作为头结点*/else
77、 while(p0->average<p1->average)&&(p1->next!=NULL) p2=p1; /*使p2指向刚才p1指向的结点*/ p1=p1->next; /*p1后移一个结点*/
78、160; if(p0->average>=p1->average) if(head=p1)head=p0; /*插到原来第一个结点之前*/ else p2->next=p0; /*插到p2指
79、向的结点之后*/ p0->next=p1; else p1->next=p0;p0->next=NULL; /*插到最后的结点之后*/ n=n+1; /*结点数加1*/head=sort(head); /*调用排序的函数,将学生成绩重新排序*/printf(
80、"nStudent %s have been inserted.n",new->name); printf("Don't forget to save the new file.n");return(head);/*保存数据到文件函数*/void save(STUDENT *head)FILE *fp; /*定义指向文件的指针*/STUDENT *p; /* 定义移动指针*/char outfile10;printf("Enter outfile name,for example c:scoren");scanf("%s",outfile);if(fp=fopen(outfile,&
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 不动产附义务赠与合同
- 长期供货合同范本
- 新能源采矿项目的合同管理
- 政府采购合同及信息透明化方案
- 翻译服务劳务分包合同示例
- 连铸丙烷站安全操作规程模版(2篇)
- 治未病科工作制度模版(二篇)
- 财务助理工作职责内容范文(2篇)
- 人力资源科安全生产岗位责任制范文(2篇)
- 2025年青年志愿者协会工作计划样本(2篇)
- 房屋无偿使用协议书(8篇)
- 中央银行理论与实务期末复习题
- 国家开放大学电大本科《国际私法》案例题题库及答案(b试卷号:1020)
- 喜庆中国节春节习俗文化PPT模板
- 测井仪器设计规范--电子设计
- 北师大版小学五年级上册数学第六单元《组合图形的面积》单元测评培优试卷
- 用特征方程求数列的通项
- 四年级奥数题(一)找规律
- 素材库管理系统架构(共13页)
- 监理平行检验记录表
- 县领导在新录用公务员培训班开班典礼上的讲话
评论
0/150
提交评论