




已阅读5页,还剩4页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
C程序 学生管理系统/* Note:Your choice is C IDE */#include stdio.h#includestdlib.h#includestring.htypedef struct student/定义学生char name10;int number;char sex2;int math;int eglish;int clanguge;int average;student;typedef struct unit/定义接点student date; struct unit *next;unit;unit* build()/建立链表并返回指针unit *p;if(p=(unit*)malloc(sizeof(unit)=NULL) printf(=初始化失败!); return 0; else p-next=NULL; p-date.number=0;/头结点存放学生人数 printf(初始化成功!n); return p; void add(unit *head)/增加学生unit *p,*q;int m,n=0;q=head-next;p=(unit*)malloc(sizeof(unit);printf(=请输入新生姓名!n); gets();fflush(stdin);printf(=请输入学号!n);while(n=0)scanf(%d,&m);fflush(stdin);if(q=NULL) n=1;while(q)if(q-date.number=m) printf(=你输入的学号与已有同学的学号相同,请重新输入!n); q=head-next; break; else q=q-next; if(q=NULL) n=1; p-date.number=m;printf(=请输入性别!n);gets(p-date.sex);fflush(stdin);printf(=请输入数学成绩n);scanf(%d,&m);fflush(stdin);p-date.math=m;printf(=请输入英语成绩n);scanf(%d,&m);fflush(stdin);p-date.eglish=m; printf(=请输入c语言成绩n);scanf(%d,&m);fflush(stdin);p-date.clanguge=m;p-date.average=(p-date.math+p-date.eglish+p-date.clanguge);q=head-next;head-next=p;p-next=q;head-date.number+;void deletion(unit *head)/删除一名学生unit *p=head-next,*q=head;char N10;printf(=请输入你想删除的学生姓名!n);gets(N);fflush(stdin);if(p=NULL)printf(=系统无学生可删除!n);while(p)if(strcmp(,N)=0)q-next=p-next;head-date.number-;printf(=删除%s成功!n,);free(p);break;elsep=p-next;q=q-next;if(p=NULL)printf(=你要删除的学生不存在,删除失败!n);int display(unit *head)/显示学生信息unit *p=head-next;int m,n=0;char N10;if(p=NULL)printf(=系统无学生!n); return 0;while(n=0)printf(*n);printf(=请选择你的操作!n);printf(=ttt1.显示所有t2.按姓名查找nttt3.按学号查找t4.返回主菜单n);scanf(%d,&m);fflush(stdin);switch(m)case 1:printf(n=该系统拥有%d名学生!nn,head-date.number); p=head-next; printf(t姓名t学号t性别t数学t英语tc语言t综合nn); while(p) printf(t%st%dt%st%dt%dt%dt%dn,,p-date.number,p-date.sex,p-date.math, p-date.eglish,p-date.clanguge,p-date.average); p=p-next; break;case 2:printf(=请输入查找姓名!n); gets(N); fflush(stdin); p=head-next; while(p) if(strcmp(,N)=0) printf(t姓名t学号t性别t数学t英语tc语言t综合n); printf(t%st%dt%st%dt%dt%dt%dn,,p-date.number,p-date.sex,p-date.math, p-date.eglish,p-date.clanguge,p-date.average); break; else p=p-next; if(p=NULL) printf(=你要查的学生不存在!); break; case 3: printf(=请输入查找学号!n); scanf(%d,&m); fflush(stdin); p=head-next; while(p) if(p-date.number=m) printf(t姓名t学号t性别t数学t英语tc语言t综合n); printf(t%st%dt%st%dt%dt%dt%dn,,p-date.number,p-date.sex,p-date.math, p-date.eglish,p-date.clanguge,p-date.average); break; else p=p-next; if(p=NULL) printf(=你要查的学生不存在!n); break; case 4:n=1;break;return 1; int range(unit *head)/排序unit *p=head,*q=head-next;int n,i,m=head-date.number;printf(*n);printf(ttt1.按学号t2.按成绩nn);printf(=请选择操作!n);scanf(%d,&n);fflush(stdin);if(q=NULL) printf(=无学生可排序!n);return 0;switch(n)case 2:for(i=0;inext; while(q-next) if(q-date.average)next-date.average) p-next=q-next; p=p-next; q-next=p-next; p-next=q; else p=p-next;q=q-next; break; case 1:for(i=0;inext; while(q-next) if(q-date.number)(q-next-date.number) p-next=q-next; p=p-next; q-next=p-next; p-next=q; else p=p-next;q=q-next; break;printf(=排序成功!n);return 1;void menu()printf(n* 主菜单 *n);printf(ttt1.新建系统t2.添加学生nttt3.删除学生t4.查看信息nttt5.排列顺序t6.读取信息nttt7.保存信息t8.退出系统n);printf(=请选择你的操作!n);int save(unit *head)/保存FILE *fp;unit *p; p=head;if(fp=fopen(d:学生,wb+)=NULL) printf(=保存失败!); return 0; while(p) fwrite(&(p-date),sizeof(student),1,fp); p=p-next; printf(=保存成功!); fclose(fp); return 1;unit* read()/读入系统学生信息int i;unit *p,*q,*head;FILE *fp;if(head=(unit*)malloc(sizeof(unit)=NULL) printf(=开辟空间失败!); exit(1); else head-next=NULL; head-date.number=0;/头结点存放学生人数 q=head; if(fp=fopen(d:学生,rb)=NULL) printf(=系统无学生!n); return 0; fread(&(q-date),sizeof(student),1,fp); for(i=0;idate.number;i+) if(p=(unit*)malloc(sizeof(unit)=NULL) printf(=读值失败!); exit(1); fread(&(p-date),sizeof(student),1,fp); p-next=q-next; q-next=p; fclose(fp); return head;void main()int m=0,n, i; unit *head; printf(*nn); printf(ttt* 欢迎使用学生成绩管理系统 * n); printf(ntttttttt编译员:岳英明nn); printf(=正在读取系统信息.n); if(head=read()=0) printf(=是否新建?n); printf(ttt是(1)tt否(2)n); scanf(%d,&i); fflush(stdin); if(i=1) head=build(); else if(i=2) exit(1); else printf(=信息导入成功!); while(m=0) menu(); scanf(%d,&n); fflush(stdin); switch(n) case 1: head=
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 绵竹中学高2023级2024-2025学年度(下)期末模拟检测(政治)
- 记账实操-金属材料销售公司的账务处理
- 河南省名校大联考2024-2025学年高一下学期4月期中生物试卷(有答案)
- 2024-2025学年下学期高二生物人教版期末必刷常考题之群落及其演替
- 2024-2025学年下学期高二生物沪科版期末必刷常考题之保护环境实现人类与自然的和谐相处
- 山东统考新闻题目及答案
- 软件学院基础题目及答案
- 日语经济题目大全及答案
- 10《静电场中的能量》-2025高中物理水平合格考备考知识清单+习题巩固
- 2 9 函数模型及应用-2026版53高考数学总复习A版精炼
- 和美乡村示范村规范方案
- 2025年政治经济学考试题及答案回顾
- 政府采购评审专家考试真题库(带答案)
- (2025)国家版图知识竞赛(附含答案)
- 2025年高考志愿填报-12种选科组合专业对照表
- 《知识产权法学》一万字笔记
- 固体废物堆肥处理技术课件
- 脑卒中的诊断与治疗
- 2025甘肃省农垦集团有限责任公司招聘生产技术人员145人笔试参考题库附带答案详解析版
- 中国古茶树资源状况白皮书2025
- 牙科技术入股合作协议书
评论
0/150
提交评论