




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、学生成绩管理系统#include stdio.h #include stdlib.h #include string.h / int shoudsave=0; struct student char num10;char name20; char sex4; int cgrade; /*c语言成绩*/int mgrade; /*高数成绩*/int egrade; /*英语成绩*/int totle; /*总分*/int ave; /*平均分*/; typedef struct node struct student data; struct node *next; node,*link; vo
2、id menu() printf(*); printf(t1登记学生资料ttttt2删除学生资料n); printf(t3查询学生资料ttttt4修改学生资料n); printf(t5保存学生资料ttttt0退出系统n); printf(*n); void printstart() printf(-n); void wrong() printf(n=提示:输入错误!n); void nofind() printf(n=提示:没有找到该学生!n); void printc() printf(学号t 姓名 性别 英语成绩 数学成绩 c语言成绩 总分 平均分n); void printe(node
3、*p) printf(%-10s%st%st%dt%dt%dt%dt%dn,p-data.num,,p-data.sex,p-data.egrade,p-data.mgrade,p-data.cgrade,p-data.totle,p-data.ave); node* locate(link l,char findmess,char nameornum) /* 该函数用于定位连表中符合要求的接点,并返回该指针 */ node *r; if(strcmp(nameornum,num)=0) /* 按学号查询 */ r=l-next; while(r!=null) if(st
4、rcmp(r-data.num,findmess)=0) return r; r=r-next; else if(strcmp(nameornum,name)=0) /* 按姓名查询 */ r=l-next; while(r!=null) if(strcmp(,findmess)=0) return r; r=r-next; return 0; void add(link l) /* 增加学生 */ node *p,*r,*s; char num10; r=l; s=l-next; while(r-next!=null) r=r-next; /* 将指针置于最末尾 */
5、while(1) printf(请你输入学号(以0返回上一级菜单:); scanf(%s,num); if(strcmp(num,0)=0) break; while(s) if(strcmp(s-data.num,num)=0) printf(=提示:学号为%s的学生已经存在,若要修改请你选择4 修改!n,num); printstart(); printc(); printe(s); printstart(); printf(n); return; s=s-next; p=(node *)malloc(sizeof(node); strcpy(p-data.num,num); printf
6、(请你输入姓名:); scanf(%s,); getchar(); printf(请你输入性别:); scanf(%s,p-data.sex); getchar(); printf(请你输入c语言成绩:); scanf(%d,&p-data.cgrade); getchar(); printf(请你输入数学成绩:); scanf(%d,&p-data.mgrade); getchar(); printf(请你输入英语成绩:); scanf(%d,&p-data.egrade); getchar(); p-data.totle=p-data.egrade+p-data.cg
7、rade+p-data.mgrade; p-data.ave=p-data.totle / 3; /* 信息输入已经完成 */ p-next=null; r-next=p; r=p; /shoudsave=1; void find(link l) /* 查询学生 */ int sel; char findmess20; node *p; if(!l-next) printf(n=提示:没有资料可以查询!n); return; printf(n=1按学号查找n=2按姓名查找n); scanf(%d,&sel); if(sel=1)/* 学号 */ printf(请你输入要查找的学号:); sca
8、nf(%s,findmess); p=locate(l,findmess,num); if(p) printf(tttt查找结果n); printstart(); printc(); printe(p); printstart(); else nofind(); else if(sel=2) /* 姓名 */ printf(请你输入要查找的姓名:); scanf(%s,findmess); p=locate(l,findmess,name); if(p) printf(tttt查找结果n); printstart(); printc(); printe(p); printstart(); el
9、se nofind(); else wrong(); void del(link l) /* 删除 */ int sel; node *p,*r; char findmess20; if(!l-next) printf(n=提示:没有资料可以删除!n); return; printf(n=1按学号删除n=2按姓名删除n); scanf(%d,&sel); if(sel=1) printf(请你输入要删除的学号:); scanf(%s,findmess); p=locate(l,findmess,num); if(p) r=l; while(r-next!=p) r=r-next; r-next
10、=p-next; free(p); printf(n=提示:该学生已经成功删除!n); /shoudsave=1; else nofind(); else if(sel=2) printf(请你输入要删除的姓名:); scanf(%s,findmess); p=locate(l,findmess,name); if(p) r=l; while(r-next!=p) r=r-next; r-next=p-next; free(p); printf(n=提示:该学生已经成功删除!n); /shoudsave=1; else nofind(); else wrong(); void modify(l
11、ink l) node *p; char findmess20; if(!l-next) printf(n=提示:没有资料可以修改!n); return; printf(请你输入要修改的学生学号:); scanf(%s,findmess); p=locate(l,findmess,num); if(p) printf(请你输入新学号(原来是%s):,p-data.num); scanf(%s,p-data.num); printf(请你输入新姓名(原来是%s):,); scanf(%s,); getchar(); printf(请你输入新性别(原来是
12、%s):,p-data.sex); scanf(%s,p-data.sex); printf(请你输入新的c语言成绩(原来是%d分):,p-data.cgrade); scanf(%d,&p-data.cgrade); getchar(); printf(请你输入新的数学成绩(原来是%d分):,p-data.mgrade); scanf(%d,&p-data.mgrade); getchar(); printf(请你输入新的英语成绩(原来是%d分):,p-data.egrade); scanf(%d,&p-data.egrade); p-data.totle=p-data.egrade+p-d
13、ata.cgrade+p-data.mgrade; p-data.ave=p-data.totle/3; printf(n=提示:资料修改成功!n); /shoudsave=1; else nofind(); void disp(link l) int count=0; node *p; p=l-next; if(!p) printf(n=提示:没有资料可以显示!n); return; printf(tttt显示结果n); printstart(); printc(); printf(n); while(p) printe(p); p=p-next; printstart(); printf(
14、n); void tongji(link l) node *maxm,*maxe,*maxc,*maxt,*maxa; /* 用于指向分数最高的接点 */ node *r=l-next; if(!r) printf(n=提示:没有资料可以统计!n); return ; maxm=maxe=maxc=maxt=maxa=r; while(r!=null) if(r-data.cgrade=maxc-data.cgrade) maxc=r; if(r-data.mgrade=maxm-data.mgrade) maxm=r; if(r-data.egrade=maxe-data.egrade) m
15、axe=r; if(r-data.totle=maxt-data.totle) maxt=r; if(r-data.ave=maxa-data.ave) maxa=r; r=r-next; printf(-统计结果-n); printf(总分最高者:t%s %d分n,,maxt-data.totle); printf(平均分最高者:t%s %d分n,,maxa-data.ave); printf(英语最高者:t%s %d分n,,maxe-data.egrade); printf(数学最高者:t%s %d分n,m
16、,maxm-data.mgrade); printf(c语言最高者:t%s %d分n,,maxc-data.cgrade); printstart(); / void sort(link l) / /link ll; /node *p,*rr,*s; /ll=(link)malloc(sizeof(node); /* 用于做新的连表 */ /ll-next=null; /if(l-next=null) / /printf(n=提示:没有资料可以排序!n); /return ; / /p=l-next; /while(p) / /s=(nod
17、e*)malloc(sizeof(node); /* 新建接点用于保存信息 */ /s-data=p-data; /s-next=null; /rr=ll; /while(rr-next!=null & rr-next-data.totle=p-data.totle) /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; /printf(n=提示:排序已经完成!n); / void save(link l)
18、 file* fp; node *p; int flag=1,count=0; fp=fopen(c:student,wb); if(fp=null) printf(n=提示:重新打开文件时发生错误!n); exit(1); p=l-next; while(p) if(fwrite(p,sizeof(node),1,fp)=1) p=p-next; count+; else flag=0; break; if(flag) printf(n=提示:文件保存成功.(有%d条记录已经保存.)n,count); /shoudsave=0; fclose(fp); void main() link l;
19、/* 链表 */ file *fp; /* 文件指针 */ int sel; char ch; char ok; int count=0; node *p,*r; printf(tttt学生成绩管理系统ntttt-光电信息工程1002班 刘俊华 (12)n); l=(node*)malloc(sizeof(node); l-next=null; r=l; fp=fopen(c:student,rb); if(fp=null) printf(n=提示:文件还不存在,是否创建?(y/n)n); scanf(%c,&ok); if(ok=y|ok=y) fp=fopen(c:student,wb); else exit(0); printf(n=提示:文件已经打开,正在导入记录.n); while(!feof
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025-2030中国划桨行业市场发展趋势与前景展望战略研究报告
- 浙江省宁波市鄞州中学2023-2024学年高一上学期12月月考物理含解析
- 知识分享周的设定计划
- 湖北省云学新高考联盟学校2022-2023学年高二下学期期中联考地理无答案
- 江西省宜春市宜丰中学2023-2024学年高一下学期开学考试 地理 含解析
- 2025浙江宁波新胜中压电器有限公司招聘5人笔试参考题库附带答案详解
- 企业内部晋升制度研究计划
- 教学工作绩效评定计划
- 体育行业保安工作总结计划
- 幼儿园小班运动会策划计划
- T-NKFA 015-2024 中小学午休课桌椅
- 课题开题报告:推进家校社协同育人研究
- 拒绝校园霸凌守护美好校园
- 不要慌太阳下山有月光二部合唱简谱
- 2025春新七年级道德与法治下册全册知识点
- Unit 9 Active learning 教学设计-2023-2024学年高中英语北师大版(2019)必修第三册
- 渔场基地建设实施方案
- 《食源性病原体》课件
- 《药品泡罩包装应用指南(征求意见稿)》
- Unit 6 Beautiful landscapes Integration 说课稿 -2024-2025学年译林版英语七年级下册001
- 2025年国家电投集团招聘笔试参考题库含答案解析
评论
0/150
提交评论