学生成绩管理系统源代码(共13页).doc

上传人:飞****2 文档编号:14944308 上传时间:2022-05-09 格式:DOC 页数:13 大小:45.50KB
返回 下载 相关 举报
学生成绩管理系统源代码(共13页).doc_第1页
第1页 / 共13页
学生成绩管理系统源代码(共13页).doc_第2页
第2页 / 共13页
点击查看更多>>
资源描述

《学生成绩管理系统源代码(共13页).doc》由会员分享,可在线阅读,更多相关《学生成绩管理系统源代码(共13页).doc(13页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上#include #include #include #include #include#include#include#include#define PRINT1 textcolor(12); cprintf(r 请按任意键返回主菜单nr);textcolor(10); getch();clrscr(); break;int shoudsave=0;struct student /* 学生信息结构体定义*/char num10,name20,cla4;int score1,score2,score3,total,ave;typedef struct nodestru

2、ct student data;struct node *next;Node,*L;void print1() cprintf(r=);void print2() cprintf(nr 1.输入学生成绩信息 在这里你可以按照提示输入学生的班级,学号,姓名及各科成绩.n); cprintf(nr 2.注销学生成绩信息 在这里你可以按照学号或姓名将某名学生的信息从本系统中删除.n); cprintf(nr 3.查询学生成绩信息 在这里你可以按照学号或姓名查询某一名学生的信息.n); cprintf(nr 4.修改学生成绩信息 在这里你可以按照提示修改某一名学生的学号,姓名及各科成绩.); cpri

3、ntf(nr 5.学生成绩信息排序 在这里你可以看到所有学生的各科成绩.n); cprintf(nr 6.学生成绩信息统计 在这里本系统将为你显示所有科目的最高分及最低分所得学生.n); cprintf(nr 7.显示学生成绩信息 在这里你可以看到系统中所有学生的信息.n); cprintf(nr 8.保存学生成绩信息 在这里你可以将学生你信息保存到内存中.n); cprintf(nr 9.帮助学生成绩信息 在这里你可以获得帮助信息.n); cprintf(nr 0.退出系统 在这里选择是否保存后,你可以安全的退出本系统.nnr );void menu() cprintf(nrxc9xcdxc

4、dxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcbxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxbb); cprintf(rxba 学生信息导入 xba 学生信息处理 xba); cprintf(rxba_xba_xba); cprin

5、tf(rxba 1-输入学生成绩信息 xba 6-学生成绩信息统计 xba); cprintf(rxba 2-注销学生成绩信息 xba 7-显示学生成绩信息 xba); cprintf(rxba 3-查询学生成绩信息 xba 8-保存学生成绩信息 xba); cprintf(rxba 4-修改学生成绩信息 xba 9-帮助学生成绩信息 xba); cprintf(rxba 5-学生成绩信息排序 xba 0-退出系统 xba); cprintf(rxc8xcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcd

6、xcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcaxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxcdxbc);void wrong() cprintf(nr输入错误!请验证后重新输入.n);void notfind()cprintf(nr该学生信息不存在!请验证后重新输入.n);void printc() /* 此函数用于输出中文格式 */cprintf(r学号 姓名 班级

7、 英语 数学 C语言 总分 平均分n );void printe(Node *p) /* 此函数用于输出英文格式 */cprintf(r%-4s%-4s%4s%5d%5d%8d%5d%7dnr,p-data.num,p-data.name,p-data.cla,p-data.score3,p-data.score2,p-data.score1,p-data.total,p-data.ave);Node* Locate(L l,char findinfo,char nameornum) /* 该函数用于定位连表中符合要求的接点,并返回该指针 */Node *r;if(strcmp(nameorn

8、um,num)=0) /* 按学号查询 */r=l-next;while(r!=NULL)if(strcmp(r-data.num,findinfo)=0)return r;r=r-next;else if(strcmp(nameornum,name)=0) /* 按姓名查询 */r=l-next;while(r!=NULL)if(strcmp(r-data.name,findinfo)=0)return r;r=r-next;return 0;void input(L l) /* 增加学生 */ Node *p,*r,*s; char num10; r=l; s=l-next;while(r

9、-next!=NULL) r=r-next; /* 将指针置于最末尾 */while(1) cprintf(r如果输入完毕,请按任意键返回主菜单n); cprintf(r如果你还想输入,请按y(yes)继续nr); scanf(%s,num); if(strcmp(num,y)=0) cprintf(请你输入学号:); scanf(%s,num); else break;while(s) if(strcmp(s-data.num,num)=0) printf(t学号为%s的学生已经存在,若要修改请你选择4 修改!n,num);print1();printc(); printe(s); prin

10、t1();printf(n); getch();return; s=s-next; p=(Node *)malloc(sizeof(Node);strcpy(p-data.num,num);cprintf(r请你输入姓名:);scanf(%s,p-data.name);getchar();cprintf(r请你输入班级:);scanf(%s,p-data.cla);getchar();cprintf(r请你输入c语言成绩(0-100):);scanf(%d,&p-data.score1);getchar();cprintf(r请你输入数学成绩(0-100):);scanf(%d,&p-data

11、.score2);getchar();cprintf(r请你输入英语成绩(0-100):);scanf(%d,&p-data.score3);getchar();p-data.total=p-data.score3+p-data.score1+p-data.score2;p-data.ave=p-data.total / 3; /* 信息输入已经完成 */p-next=NULL;r-next=p;r=p;shoudsave=1;void query(L l) /* 查询学生信息 */int select;char findinfo20;Node *p;if(!l-next)cprintf(n

12、没有信息可以查询!n);return;cprintf(n1=按学号查找nr2=按姓名查找nr);scanf(%d,&select);if(select=1) /* 学号 */cprintf(r请你输入要查找的学号:);scanf(%s,findinfo);p=Locate(l,findinfo,num);if(p)cprintf( 查找结果nr);print1();printc();printe(p);print1();elsenotfind();else if(select=2) /* 姓名 */cprintf(r请你输入要查找的姓名:);scanf(%s,findinfo);p=Locat

13、e(l,findinfo,name);if(p)cprintf( 查找结果nr);print1();printc();printe(p);print1();elsenotfind();elsewrong();void Delete(L l) /* 删除学生信息 */int select;Node *p,*r;char findinfo20;if(!l-next)cprintf(n 没有信息可以删除!n);return;cprintf(n1=按学号删除nr2=按姓名删除nr);scanf(%d,&select);if(select=1)cprintf(r请你输入要删除的学号:);scanf(%s

14、,findinfo);p=Locate(l,findinfo,num);if(p)r=l;while(r-next!=p)r=r-next;r-next=p-next;free(p);cprintf(nr该学生已经成功删除!n);shoudsave=1;elsenotfind();else if(select=2)cprintf(r请你输入要删除的姓名:);scanf(%s,findinfo);p=Locate(l,findinfo,name);if(p)r=l;while(r-next!=p)r=r-next;r-next=p-next;free(p);cprintf(nr该学生已经成功删除

15、!n);shoudsave=1;elsenotfind();else wrong();void modify(L l) /*修改学生信息*/Node *p;char findinfo20;if(!l-next)cprintf(nr没有信息可以修改!n);return;cprintf(r请你输入要修改的学生学号:);scanf(%s,findinfo);p=Locate(l,findinfo,num);if(p)cprintf(r请你输入新学号(原来是%s):,p-data.num);scanf(%s,p-data.num);cprintf(r请你输入新姓名(原来是%s):,p-data.nam

16、e);scanf(%s,p-data.name);getchar();cprintf(r请你输入新班级(原来是%s):,p-data.cla);scanf(%s,p-data.cla);cprintf(r请你输入新的c语言成绩(原来是%d分):,p-data.score1);scanf(%d,&p-data.score1);getchar();cprintf(r请你输入新的数学成绩(原来是%d分):,p-data.score2);scanf(%d,&p-data.score2);getchar();cprintf(r请你输入新的英语成绩(原来是%d分):,p-data.score3);scan

17、f(%d,&p-data.score3);p-data.total=p-data.score3+p-data.score1+p-data.score2;p-data.ave=p-data.total/3;cprintf(nr信息修改成功!n);shoudsave=1;elsenotfind();void display(L l) /*显示全部学生信息*/int count=0;Node *p;p=l-next;if(!p)cprintf(nr 没有信息可以显示!n);return;cprintf( 显示结果 );print1();printc();while(p) if(count%5=0)

18、getch();printe(p);p=p-next;count+;print1();cprintf(n);void Statistic(L l) /*统计学生信息*/ Node *pm_max,*pe_max,*pc_max,*pt_max,*pa_max; /* 用于指向分数最高的接点 */Node *pm_min,*pe_min,*pc_min,*pt_min,*pa_min;Node *r=l-next;if(!r)cprintf(nr 没有信息可以统计!n);return ;pm_max=pe_max=pc_max=pt_max=pa_max=pm_min=pe_min=pc_min

19、=pt_min=pa_min=r;while(r!=NULL) if(r-data.score1=pc_max-data.score1)pc_max=r;if(r-data.score1data.score1)pc_min=r;if(r-data.score2=pm_max-data.score2)pm_max=r;if(r-data.score2data.score2)pm_min=r;if(r-data.score3=pe_max-data.score3)pe_max=r;if(r-data.score3data.score3)pe_min=r;if(r-data.total=pt_max

20、-data.total)pt_max=r;if(r-data.totaldata.total)pt_min=r;if(r-data.ave=pa_max-data.ave)pa_max=r;if(r-data.avedata.ave)pa_min=r;r=r-next;cprintf(=统计结果=n);cprintf(r总分最高者: %-16s %d分n,pt_max-data.name,pt_max-data.total);cprintf(r平均分最高者: %-16s %d分n,pa_max-data.name,pa_max-data.ave);cprintf(r英语最高者: %-16s %

21、d分n,pe_max-data.name,pe_max-data.score3);cprintf(r数学最高者: %-16s %d分n,pm_max-data.name,pm_max-data.score2);cprintf(rc语言最高者: %-16s %d分nr,pc_max-data.name,pc_max-data.score1);cprintf(r总分最低者: %-16s %d分n,pt_min-data.name,pt_min-data.total);cprintf(r平均分最低者: %-16s %d分n,pa_min-data.name,pa_min-data.ave);cpri

22、ntf(r英语最低者: %-16s %d分n,pe_min-data.name,pe_min-data.score3);cprintf(r数学最低者: %-16s %d分n,pm_min-data.name,pm_min-data.score2);cprintf(rc语言最低者: %-16s %d分nr,pc_min-data.name,pc_min-data.score1);print1(); void Sort(L l)L ll;Node *p,*rr,*s; ll=(L)malloc(sizeof(Node); /* 用于做新的连表 */ll-next=NULL; if(l-next=N

23、ULL)cprintf(nr 没有信息可以排序!n);return ; p=l-next; while(p)s=(Node*)malloc(sizeof(Node); /* 新建接点用于保存信息 */s-data=p-data;s-next=NULL;rr=ll;while(rr-next!=NULL & rr-next-data.total=p-data.total)rr=rr-next;if(rr-next=NULL)rr-next=s;else s-next=rr-next;rr-next=s; p=p-next; free(l);l-next=ll-next;cprintf(nr 排序

24、已经完成!n);void Save(L l) /* */FILE* fp; Node *p;int flag=1,count=0; fp=fopen(c:student,wb); if(fp=NULL)cprintf(nr 重新打开文件时发生错误!n);exit(1);p=l-next;while(p)if(fwrite(p,sizeof(Node),1,fp)=1)p=p-next;count+;elseflag=0;break;if(flag)cprintf(nr 文件保存成功.(有%d条信息已经保存.)nr,count);shoudsave=0;fclose(fp);void main(

25、) /* */L l; /* 链表 */FILE *fp; /* 文件指针 */int count=0 ,i,menu_select; /*菜单选择 */char ch ,creat;Node *p,*r;time_t it;clrscr(); textmode(C80);window(1,1,80,25);textbackground(1); clrscr();textcolor(10);printf(r 学生成绩管理系统 );printf(r -扬州大学信息工程学院软件0902班 ) ;printf(r 设计人员:李天鹏 );l=(Node*)malloc(sizeof(Node);l-n

26、ext=NULL;r=l;fp=fopen(c:student,rb);if(fp=NULL)cprintf(nr 该文件还未存在,是否需要创建?(y/n,Y/N)nr);scanf(%c,&creat);if(creat=y|creat=Y)fp=fopen(c:student,wb);elseexit(0);gotoxy(9,11); textcolor(12);cprintf(nr 文件已经打开,系统正在导入信息);for(i=0;inext=NULL;r-next=p;r=p; /* 将该接点挂入连中 */count+;fclose(fp); /* 关闭文件 */gotoxy(1,3)

27、;cprintf(nr信息导入完毕,系统共导入%d条信息 ,count);sleep(1);while(1) menu();textcolor(12);cprintf(r现在时间: ); it=time(NULL);cprintf(ctime(&it);cprintf(r左边数字对应功能选择,请按0-9选择操作:nr);textcolor(10) ;scanf(%d,&menu_select);if(menu_select=0)if(shoudsave=1) getchar(); textcolor(128+12);cprintf(nr 信息已经改动,是否将改动保存到文件中(y/n Y/N)?

28、nr);scanf(%c,&ch);if(ch=y|ch=Y)Save(l);cprintf(nr 你已经成功退出学生成绩信息系统,欢迎下次继续使用!n);break;switch(menu_select)case 1: clrscr(); input(l); clrscr(); break; /* 输入学生 */ case 2: clrscr(); Delete(l); PRINT1 /* 删除学生 */ case 3: clrscr(); query(l); PRINT1 /* 查询学生 */ case 4: clrscr(); modify(l); PRINT1 /* 修改学生 */ case 5: clrscr(); Sort(l); PRINT1 case 6: clrscr(); Statistic(l); PRINT1 case 7: clrscr(); display(l); PRINT1 case 8: clrscr(); Save(l); PRINT1 /* 保存学生 */ case 9: clrscr(); cprintf( =帮助信息=n); print2(); PRINT1 ; default: wrong(); getchar(); break;专心-专注-专业

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁