C语言学生管理系统源代码_第1页
C语言学生管理系统源代码_第2页
C语言学生管理系统源代码_第3页
C语言学生管理系统源代码_第4页
C语言学生管理系统源代码_第5页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、C语言学生成绩管理系统源代码,保证能用#include malloc.h#include stdio.h#include stdlib.h#include string.hchar filename30;int n=0,d;FILE *fp;typedef struct studentint num;char name10;int yuwen;int shuxue;int yingyu;int count;float aver;struct student *next; aaa;typedef struct stuint num;char name10;int yuwen,shuxue,yin

2、gyu;int count; float aver; aaaa;aaa *head;/*浏览*/void liulan(aaa *head)aaa *p;if(head=NULL)printf(n没有任何学生资料!n);else printf(ttt考试成绩管理系统n); printf(-n); printf(|学号t|姓名t|语文t|数学t|英语t|总分t|平均分|n);printf(-n); p=head-next;doprintf(|%dt|%st|%dt|%dt|%dt|%dt|%.1ft|n,p-num,p-name,p-yuwen,p-shuxue,p-yingyu,p-yuwen

3、+p-shuxue+p-yingyu,p-count/3.0);printf(-n);p=p-next;while(p!=NULL);/*读取*/aaa *duqu ()aaa *s,*head,*p,*q;n=0;if(fp=fopen(filename,rb)=NULL)printf(不能读取文件!n);return NULL;head=malloc(sizeof(aaa);if(head=NULL)printf(内存空间不足,文件读取失败!n);return NULL;head-next=NULL;p=head;q=malloc(sizeof(aaa);if(!feof(fp) frea

4、d(q,sizeof(aaaa),1,fp); q-next=NULL;while(!feof(fp)s=malloc(sizeof(aaa);fread(s,sizeof(aaaa),1,fp); s-next=NULL;p-next=q;p=q;q=s; n+;return head;/*输入函数*/aaa *shuru (aaa *head)aaa *q,*p,*s;aaa newstd;n=0;q=head;doq=head;s=malloc(sizeof(aaa);if(s=NULL)printf(内存不足,添加学生成绩失败!07n);break;printf(请输入学号(输入0退出

5、):);scanf(%d,&newstd.num);if(newstd.num=0)break;if(newstd.numnext;while(p!=NULL)if(p-num=newstd.num)printf(输入学号重复,请重新输入!n);break;p=p-next;q=q-next;if(p=NULL)printf(姓名:);scanf(%s,);printf(语文:);scanf(%d,&newstd.yuwen); printf(数学:);scanf(%d,&newstd.shuxue);printf(英语:);scanf(%d,&newstd.yingyu

6、);strcpy(s-name,);s-num=newstd.num;s-yuwen=newstd.yuwen;s-shuxue=newstd.shuxue;s-yingyu=newstd.yingyu;s-count=s-yuwen+s-shuxue+s-yingyu;s-aver=(float)(s-count/3.0);s-next=NULL;q-next=s;n+;while(1);printf(输入完毕,%d个学生成绩已输入(已插入)n,n);return head;/*保存*/int baocun (aaa *head)aaa *s;s=head-next;i

7、f(fp=fopen(filename,wb)=NULL)printf(不能写入文件!保存失败!n);return 0;while(s!=NULL)fwrite(s,sizeof(aaaa),1,fp);s=s-next;fclose(fp);return 1;/*保存文件*/int save (aaa *head)int i=0;aaa *s;s=head-next;printf(请输入文件路径及文件名:);scanf(%s,filename);if(fp=fopen(filename,wb)=NULL)printf(不能建立文件!n);return 0;while(s!=NULL)fwri

8、te(s,sizeof(aaaa),1,fp);s=s-next;i+;fclose(fp);printf(%d名学生成绩记录写入%s中!n,i,filename);printf(文件保存成功!n);return 1;/*打开文件*/aaa *dakai (void)aaa *s,*head,*p,*q;n=0;printf(请输入文件路径及文件名:);scanf(%s,filename);if(fp=fopen(filename,rb)=NULL)printf(不能读取文件!n);return NULL;head=malloc(sizeof(aaa);if(head=NULL)printf(

9、内存空间不足,文件打开失败!n);return NULL;head-next=NULL;p=head;q=malloc(sizeof(aaa);if(!feof(fp) fread(q,sizeof(aaaa),1,fp); q-next=NULL;while(!feof(fp)s=malloc(sizeof(aaa);fread(s,sizeof(aaaa),1,fp); s-next=NULL;p-next=q;p=q;q=s; n+;liulan(head);printf(-n);printf(文件已打开,%d个记录已读取n,n);d=baocun(head);getchar();ret

10、urn head;/*建立*/aaa *great()aaa *head;head=malloc(sizeof(aaa);if(head=NULL)printf(内存空间不足,链表建立失败!07n);return NULL;head-next=NULL;head-num=0;head=shuru(head);d=save(head);return head;/*查询*/int chaxun(aaa *head)aaa *q;int i;if(head=NULL)printf(n没有任何的学生资料!n);return 0;printf(需要查询的学号:);scanf(%d,&i);q=head-

11、next;while(q-num!=i & q!=NULL)q=q-next;if(q!=NULL)printf(学号t姓名t语文t数学t英语t总分t平均分n);q-count=q-yuwen+q-shuxue+q-yingyu;q-aver=(float)(q-count/3.0);printf(%dt%st%dt%dt%dt%dt%.1fn,q-num,q-name,q-yuwen,q-shuxue,q-yingyu,q-count,q-aver);return 0;elseprintf(查无此人!n);return 0;/*删除*/aaa *shanchu(aaa *head)aaa *

12、s,*q;int m;head=duqu();if(head=NULL)printf(没有任何学生记录!n);exit(0);printf(请输入要删除的学生学号); scanf(%d,&m);if(m=0)return head;s=head;q=s-next;while(q-num!=m & q!=NULL)q=q-next;s=s-next;if(q!=NULL)printf(学号:%d 姓名:%s 语文:%d 数学:%d 英语:%d 总分:%d 平均分:%.1fn,q-num,q-name,q-yuwen,q-shuxue,q-yingyu,q-yingyu+q-shuxue+q-yu

13、wen,q-count/3.0);s-next=q-next;free(q);printf(删除学号为%d学生记录成功!n,m);elseprintf(查无此人!n);liulan(head);d=baocun(head);return head;/*排序*/aaa *paixu(aaa *head)aaa *p,*max,*q;int i,j,m;char t10;head=duqu();if(head=NULL)printf(n没有任何学生资料!07n);return NULL;exit(0);q=head;printf(按总成绩排序所有学生n);for(i=0;inext;for(j=i

14、+1;jnext;if(max-countcount)max=p;if(max!=q) m=max-num;max-num=q-num;q-num=m;strcpy(t,max-name); strcpy(max-name,q-name); strcpy(q-name,t);m=max-yuwen;max-yuwen=q-yuwen;q-yuwen=m;m=max-shuxue;max-shuxue=q-shuxue;q-shuxue=m;m=max-yingyu;max-yingyu=q-yingyu;q-yingyu=m;q-count=q-yuwen+q-shuxue+q-yingyu;

15、q-aver=(float)(q-count/3.0);d=baocun(head);return head;/*插入*/aaa *charu(aaa *head)aaa *s,*p;s=p=head;p=shuru(s);p=paixu(p);printf(插入完毕!n);liulan(head);d=baocun(head);return head;/*修改*/aaa *xiugai(aaa *head)aaa *q;int m;if(head=NULL)printf(n没有任何学生记录!n);return NULL;q=head-next;printf(请输入要修改的学生的学号:);sc

16、anf(%d,&m);while(q-num!=m & q!=NULL)q=q-next;if(q=NULL)printf(查无此人!n);printf(学号:%d 姓名:%s 语文:%d 数学:%d 英语:%d 总分:%d 平均分:%.1fn,q-num,q-name,q-yuwen,q-shuxue,q-yingyu,q-yuwen+q-shuxue+q-yingyu,q-count/3.0);printf(请输入修改之后的学号:);scanf(%d,&q-num);printf(请输入修改之后的姓名:);scanf(%s,q-name);printf(请输入修改之后的语文:);scanf

17、(%d,&q-yuwen);printf(请输入修改之后的数学:);scanf(%d,&q-shuxue);printf(请输入修改之后的英语:);scanf(%d,&q-yingyu);printf(修改成功n);q-count=q-yuwen+q-shuxue+q-yingyu;q-aver=(float)(q-count/3.0);printf(学号:%d 姓名:%s 语文:%d 数学:%d 英语:%d 总分:%d 平均分:%.1fn,q-num,q-name,q-yuwen,q-shuxue,q-yingyu,q-count,q-aver);d=baocun(head);head=du

18、qu();head=paixu(head);printf(学号为%d学生数据修改成功!n,m);liulan(head); return head;/*主函数*/main()aaa *head;int m;doprintf(n);printf(t*n);printf(t* = *n);printf(t* 学生成绩管理系统 *n);printf(t* = *n);printf(t* *n);printf(t* 1.输入学生成绩 *n);printf(t* 2.打开记录文件 *n);printf(t* 3.查找学生成绩 *n);printf(t* 4.修改学生信息 *n);printf(t* 5.删除学生信息 *n);printf(t* 6.插入学生信息 *n);printf(t* 7.学生成绩排序 *n);printf(t* 8.浏览学生信息 *n);printf(t* 9.保存输入数据 *n);printf(t* 0退出 *n);printf(t* *n);printf(t*n);printf(请输入选项(0-9):);scanf

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论