




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、题目名称: 学生信息管理系统 算法分析: 1用结构体标出信息系统的成员:学生学号,学生姓名,班级,成绩,排名2 利用c语言的文件知识将系统的信息存放在c盘下的“zuoye.txt”的文件夹下3 定义各个子函数(1)定义输入信息函数,将学生信息按一定格式用scanf函数输入(统计M个学生的信息);(2)定义输出函数,每两个表一页直到最后一个;(3)定义信息查询函数。a,定义按学号查询函数,如果输入的学号等于学生学号则输出要查询的信息;b,定义按姓名查询函数,如果输入的姓名字符串等于其中一个学生的姓名字符串则输出信息;c,定义按班级查找函数,如果输入的数字等于其中学生的班级数,则输出该信息;d,定
2、义按成绩查找函数,如果输入的数字等于其中学生的成绩数,则输出该信息;e,定义查找总函数,输入一个数选择查找方式,1-4分别对应调用abcd四个函数。(4)定义删除信息函数。输入的数字作为要删除的学生学号,输出要删除的学生信息后选择是否删除,删除后将第g+1个的信息赋给第g个,输出删除后的信息表。(5)定义信息修改函数。输入的数字等于要修改的学生学号,输出要修改的学生信息后选择是否修改,用switch,case语句选择要修改的项目,输入n,y决定是否继续直到不继续修改,输出学生信息。(6)定义信息统计函数。输入一个数字作为成绩,比较M个学生成绩是否等于输入的数字,统计相等的个数n输出。(7)定义
3、成绩排序函数。用冒泡排序法将M个学生的成绩按从大到小的顺序排列后输出。4 定义主函数。调用读取文件函数,输入数字1-5分别对应调用修改学生信息函数,删除学生信息函数,查找学生信息函数,统计学生信息函数,学生成绩排行信息函数,0表示退出系统。最后调用保存文件函数。结束程序。流程设计:学生信息管理系统程序用结构体说明各个成员定义各个子函数定义成绩排序函数定义统计函数定义删除信息函数定义修改信息函数定义输入输出函数定义信息查询函数用冒泡排序法将M个学生的成绩按从大到小排列比较成绩数是否等于输入数选择要删除的学号,判断是否删除switch,case语句选择查询方式选择要修改的信息1-4定义按学号,姓名
4、,班级,成绩的函数计数,输出n将第g+1个信息赋给第g个判断是否继续修改直到不继续,结束定义主函数,用switch case选择要调用的子函数保存文件退出系统结束程序代码设计:#include<stdio.h>#include<stdlib.h>#include<string.h>#define M 2#define PAGE 2 /*学生信息结构体类型*/ typedef struct int num; /*学号*/ char name20; /*姓名*/ int banji; /*班级*/ int chengji; /*成绩*/ int paiming;
5、 /*排名*/ STUDENTS; int read_file(STUDENTS students)/*文件的读取*/ FILE *fp;/*定义一个文件指针变量*/ int i=0; if(fp=fopen("zuoye.txt","r")=NULL)/*文件空判断,fopen打开一个文件*/ printf("nn*库存文件不存在!请创建"); return 0; while(feof(fp)!=1)/*文件是否结束*/ fread(&studentsi,sizeof(STUDENTS),1,fp);/*读取文件*/ if(
6、studentsi.num=0)/*学号是否为零*/ break; else i+; fclose(fp);/*关闭文件*/ return i; void save_file(STUDENTS students,int sum)/*保存文件*/ FILE *fp; int i; if(fp=fopen("zuoye.txt","wb")=NULL)/*判断文件是否为空*/ printf("读文件错误!n"); return; for(i=0;i<sum;i+) if(fwrite(&studentsi,sizeof(ST
7、UDENTS),1,fp)!=1)/*向文件写入的数据块不等于1*/ printf("写文件错误!n"); fclose(fp); /*输入模块*/ int input(STUDENTS students) int i=0; printf("nn 录入学生信息 (最多%d人)n",M); printf("-n"); do printf("n 第%d人",i+1); printf("n 学生学号:"); scanf("%d",&studentsi.num); if(st
8、udentsi.num=0) break; printf("n 学生姓名:"); scanf("%s",); printf("n 班级:"); scanf("%d",&studentsi.banji); printf("n 成绩:"); scanf("%d",&studentsi.chengji); printf("n 排名:"); scanf("%d",&studentsi.paim
9、ing); i+; while(i<M); printf("n -%d个学生信息输入完毕!-n",i); printf("n 按任意键返回主菜单!"); getchar(); return i; /*输出模块*/ void output(STUDENTS students) int i=0,j=0,page=1;printf("nn -学生信息表- 第%d页nn",page);/*每两个一页*/ printf("学生学号-姓名-班级- 成绩-排名n"); printf("-n"); do
10、if(studentsi.num!=0) j+; if(j%PAGE!=0) printf("%12d %10s %2d %3d %4d n",studentsi.num,, studentsi.banji, studentsi.chengji,studentsi.paiming); printf("-n"); else printf("按任意键继续!"); getchar(); printf("nn -学生信息表- 第%d页nn",+page); printf("学生学号-姓
11、名-班级- 成绩-排名n"); printf("-n"); printf("%12d %10s %2d %3d %4d n",studentsi.num,, studentsi.banji, studentsi.chengji,studentsi.paiming); printf("-n"); i+; while(studentsi.num<M); printf("按任意键返回主菜单!"); getchar( ); /*学生信息查询*/ void find_by_num(
12、STUDENTS students,int sum) /*按学号查找*/ int i,find_num; printf("n 请输入要查找的学生学号:"); scanf("%d",&find_num); for(i=0;i<sum;i+) if(studentsi.num=find_num) printf("这是您所查找到的学生信息:n"); printf("学生学号-姓名-班级- 成绩-排名n"); printf("-n"); printf("%12d %10s %2d
13、 %3d %4d n",studentsi.num,, studentsi.banji, studentsi.chengji,studentsi.paiming); printf("-n"); break; else printf("n 未找到要查找的学生信息,按任意键返回!"); getchar(); void find_by_name(STUDENTS students,int sum)/*按姓名查找*/ int i; char find_name20; printf("n 请输入要查找的学生姓名:&q
14、uot;); scanf("%s",find_name); for(i=0;i<sum;i+); if(strcmp(,find_name)=0) /*字符串比较相等返回0*/ printf("这是您所查找到属于该学生的信息:");printf("学生学号-姓名-班级- 成绩-排名n");printf("-n");printf("%12d %10s %2d %3d %4d n",studentsi.num,, studentsi.ba
15、nji, studentsi.chengji,studentsi.paiming);printf("-n"); else printf("n 未找到要查找的学生信息,按任意键返回!");getchar(); void find_by_banji(STUDENTS students,int sum)/*按班级查找*/ int i; int find_banji; printf("n 请输入要查找的学生班级:"); scanf("%d",&find_banji); for(i=0;i<sum;i+)if(
16、studentsi.banji=find_banji)printf("这是您所查找到属于该班级的学生:"); printf("学生学号-姓名-班级- 成绩-排名n"); printf("-n"); printf("%12d %10s %2d %3d %4d n",studentsi.num,, studentsi.banji, studentsi.chengji,studentsi.paiming); printf("-n"); else printf("n
17、 未找到要查找的班级信息,按任意键返回!");getchar(); void find_by_chengji(STUDENTS students,int sum)/*按成级查找*/ int i; int find_chengji; printf("n 请输入要查找的学生成绩:"); scanf("%d",&find_chengji); for(i=0;i<sum;i+) if(studentsi.chengji=find_chengji) printf("这是您所查找到有该成绩的学生:"); printf(&q
18、uot;学生学号-姓名-班级- 成绩-排名n"); printf("-n"); printf("%12d %10s %2d %3d %4d n",studentsi.num,, studentsi.banji, studentsi.chengji,studentsi.paiming); printf("-n"); else printf("n 未找到要查找的学生信息,按任意键返回!");getchar(); void find(STUDENTS students,int sum
19、)/*定义查找总函数*/ int choice; printf("n 您要按照哪种方式查找? n");/*用switch语句*/ printf("n 1.按学生学号查找 n"); printf("n 2.按学生姓名查找 n"); printf("n 3.按学生班级查找 n"); printf("n 4.按学生成绩查找 n"); printf("n 0. 退出n"); printf("n 请选择(0-4): n"); scanf("%d"
20、,&choice); switch(choice) case 1: find_by_num(students,sum); break; case 2: find_by_name(students,sum); break; case 3: find_by_banji(students,sum); break; case 4: find_by_chengji(students,sum); break; case 0: break; /*删除信息模块*/ void del(STUDENTS students) int i,g,sum; int del_num; printf("n
21、请输入要删除的学生学号:"); scanf("%d",&del_num); for(i=0;i<sum;i+) if(studentsi.num=del_num)/*通过学号判断*/ printf("这是您所要删除学生信息:n"); printf("学生学号-姓名-班级- 成绩-排名n"); printf("-n"); printf("%12d %10s %2d %3d %4d n",studentsi.num,, studentsi.banj
22、i, studentsi.chengji,studentsi.paiming); printf("-n"); printf("您确认要删除吗?"); printf("按任意键继续!"); getchar(); printf("已成功删除学生信息!"); for(g=i;g<sum;g+) studentsg=studentsg+1; printf("删除后的信息表:n"); printf("学生学号-姓名-班级- 成绩-排名n"); printf("-n&qu
23、ot;); printf("%12d %10s %2d %3d %4d n",studentsi.num,, studentsi.banji, studentsi.chengji,studentsi.paiming); printf("-n"); /*信息修改模块*/ void modify(STUDENTS students,int sum) int i=0,choice,modify_num,flag; do printf("请输入要修改的学生学号:"); scanf("%d",&a
24、mp;modify_num); for(i=0;i<sum;i+) if(studentsi.num=modify_num) printf("nn -学生信息- nn"); printf("学生学号-姓名-班级- 成绩-排名n"); printf("-n"); printf("%12d %10s %2d %3d %4d n",studentsi.num,, studentsi.banji, studentsi.chengji,studentsi.paiming); printf(&
25、quot;-n"); printf("n 您要修改哪一项?n"); printf("n 1.学生姓名n"); printf("n 2.学生班级n"); printf("n 3.成绩n"); printf("n 4.排名n"); printf("n 请选择(1-4):n"); scanf("%d",&choice); switch(choice) case 1: printf("n 请输入修改后的学生姓名:"); sca
26、nf("%s",); break; case 2: printf("n 请输入修改后的学生班级:"); scanf("%s",studentsi.banji); break; case 3: printf("n 请输入修改后的成绩:"); scanf("%s",studentsi.chengji); break; case 4: printf("n 请输入修改后的排名:"); scanf("%d",&studentsi.
27、paiming); break; printf("nn -学生信息- nn"); printf("学生学号-姓名-班级- 成绩-排名n"); printf("-n"); printf("%12d %10s %2d %3d %4d n",studentsi.num,, studentsi.banji, studentsi.chengji,studentsi.paiming); printf("-n"); break; else printf("n 该学生不存在
28、!"); printf("n 修改成功!n"); printf("您要继续修改吗?(Y/N)"); if (choice='Y'|choice='y') flag=1; printf("n 继续!n"); else flag=0; while( flag=1); /*直到不修改结束循环*/ printf("n 按任意键返回主菜单!"); getchar(); /*学生信息统计模块*/void count(STUDENTS students,int sum) /*统计某个成绩
29、的学生个数*/ int i; int count_chengji; int n=0; printf("请输入一个成绩:n"); scanf("%d",&count_chengji); for(i=0;i<sum;i+) if(studentsi.chengji=count_chengji)/*计数*/ n+; break; printf("统计出属于该成绩的一共有%d个人n",n);/*成绩排序模块*/ void sort(STUDENTS students,int sum) STUDENTS t; int i,j; printf("nn -学生信息- nn"); printf("学生学号-姓名-班级- 成绩-排名n"); printf("-n"); for(i=1;i<sum;i+) for(j=i+1;j<sum;j+) if(studentsj.ch
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 课件中文字使用原则
- 2025年建筑工程监理师职业技术能力考试试卷及答案解析
- 2025年家庭摄影师职业水平评定试题及答案解析
- 2025年机械制造工程师综合知识技能考核试卷及答案解析
- 2025年数据安全工程师bi备题库
- 2025年公共关系师资格考试试题及答案解析
- 机电施工标准课件
- 2025年职场安全常识问卷及答案解析
- 2025年防汛安全操作试题及答案大全
- 2025年社交媒体营销专家面试技巧与案例分析题集
- 培训钉钉课件
- 新建洞室储气库压缩空气储能系统的经济性及成本分析
- 艺康servsafe培训课件
- 砖厂职业危害管理制度
- 肝功能障碍患者的麻醉管理要点
- 2025年粮油仓储管理员(高级)职业技能鉴定考试练习题库(含答案)
- 【课件】新高三启动主题班会:启航高三逐梦未来
- 历史 2024-2025学年部编版七年级历史下学期期末问答式复习提纲
- 2025年中国邮政集团有限公司北京分公司招聘笔试冲刺题(带答案解析)
- 学校物业服务应急事件处理预案
- 单位车辆管理委托协议书示例3篇
评论
0/150
提交评论