版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、#include #include /定义学生结构体/ struct Student char ID8; char Name20; float Mark1; float Mark2; float Mark3; float Average; int mark1;int mark2;int mark3;long int kcbh1;long int kcbh2;long int kcbh3;char kecheng129;char kecheng229;char kecheng329; /声明学生数组及学生数量/ struct Student students1000; int num=0; /求
2、平均值/ float Avg(struct Student stu) return (stu.mark1*stu.Mark1+stu.mark2+stu.Mark2+stu.mark3+stu.Mark3)/(stu.Mark1+stu.Mark2+stu.Mark3); /通过学号返回/ int Student_SearchByIndex(char id) int i; for (i=0;inum;i+) if (strcmp(studentsi.ID,id)=0) return i; return -1; /通过姓名返回数组下标/ int Student_SearchByName(char
3、 name) int i; for (i=0;inum;i+) if (strcmp(studentsi.Name,name)=0)/比较参数中两个字符串的大小如果完全相等,返回0/ return i; /这个return表示退出函数,回到调用这个函数的位置/ return -1; /显示单条学生记录/ void Student_DisplaySingle(int index) printf(学号:%10s 姓名:%10sn,studentsindex.ID,studentsindex.Name);printf( 课程编号:%8ld 课程: %8s 学分: %8f 成绩 : %8dn,stud
4、entsindex.kcbh1 , studentsindex.kecheng1 ,studentsindex.Mark1, studentsindex.mark1);printf( 课程编号:%8ld 课程: %8s 学分: %8f 成绩 : %8dn,studentsindex.kcbh2 , studentsindex.kecheng2 , studentsindex.Mark2, studentsindex.mark2);printf( 课程编号:%8ld 课程: %8s 学分: %8f 成绩 : %8dn,studentsindex.kcbh3 , studentsindex.kec
5、heng3 , studentsindex.Mark3, studentsindex.mark3);printf( 平均成绩%10fn,studentsindex.Average); /显示pingjunzhi/ void Student_DisplayAverage(int index) printf( 平均成绩%10fn,studentsindex.Average); /插入学生信息/ void Student_Insert() while(1) printf(请输入学号:); scanf(%s,&studentsnum.ID); getchar(); /未输入n,继续/ printf(请
6、输入姓名:); scanf(%s,&studentsnum.Name); getchar(); printf(请输入课程编号:); scanf(%ld,&studentsnum.kcbh1); getchar(); printf(请输入课程:); scanf(%s,&studentsnum.kecheng1); getchar(); printf(请输入学分:); scanf(%f,&studentsnum.Mark1); getchar(); printf(请输入成绩:); scanf(%d,&studentsnum.mark1); getchar(); printf(请输入课程编号:);
7、scanf(%ld,&studentsnum.kcbh2); getchar(); printf(请输入课程:); scanf(%s,&studentsnum.kecheng2); getchar(); printf(请输入学分:); scanf(%f,&studentsnum.Mark2); getchar(); printf(请输入成绩:); scanf(%d,&studentsnum.mark2); getchar(); printf(请输入课程编号:); scanf(%ld,&studentsnum.kcbh3); getchar(); printf(请输入课程:); scanf(%s
8、,&studentsnum.kecheng3); getchar(); printf(请输入学分:); scanf(%f,&studentsnum.Mark3); getchar(); printf(请输入成绩:); scanf(%d,&studentsnum.mark3); getchar(); studentsnum.Average=Avg(studentsnum); num+; printf(是否继续?(y/n); if (getchar()=n) break; /删除学生信息/ void Student_Delete() int i; while(1) char id20; int i
9、ndex; printf(请输入要删除的学生的学号:); scanf(%s,&id); getchar(); index=Student_SearchByIndex(id); if (index=-1) printf(学生不存在!n); else /找到了/ printf(你要删除的学生信息为:n); Student_DisplaySingle(index); printf(是否真的要删除?(y/n); if (getchar()=y) for (i=index;inum-1;i+) studentsi=studentsi+1; num-; getchar(); printf(是否继续?(y/
10、n); if (getchar()=n) break; /按姓名查询/ void Student_Select() while(1) char name20; int index; printf(请输入要查询的学生的姓名:); scanf(%s,&name); getchar(); index=Student_SearchByName(name); if (index=-1) printf(学生不存在!n); else printf(你要查询的学生信息为:n); Student_DisplaySingle(index); printf(是否继续?(y/n); if (getchar()=n)
11、break; /pingjunzhi/ void Student_modify() while(1) char name20; int index; printf(请输入要查询的学生的姓名:); scanf(%s,&name); getchar(); index=Student_SearchByName(name); if (index=-1) printf(学生不存在!n); else printf(你要查询的学生信息为:n); Student_DisplayAverage(index); printf(是否继续?(y/n); if (getchar()=n) break; /按平均值排序/
12、 void Student_SortByAverage() int i,j; struct Student tmp; for (i=0;inum;i+) for (j=1;jnum-i;j+) if (studentsj-1.Averagestudentsj.Average) tmp=studentsj-1; studentsj-1=studentsj; studentsj=tmp; /交换位置/ /显示学生信息/ void Student_Display() int i; for (i=0;inum;i+) printf(学号:%10s 姓名:%10sn,studentsi.ID,stude
13、ntsi.Name); printf( 课程编号:%8ld 课程: %8s 学分: %8f 成绩 : %8dn,studentsi.kcbh1 ,studentsi.kecheng1 ,studentsi.Mark1, studentsi.mark1); printf( 课程编号:%8ld 课程: %8s 学分: %8f 成绩 : %8dn,studentsi.kcbh2 , studentsi.kecheng2 , studentsi.Mark2, studentsi.mark2); printf( 课程编号:%8ld 课程: %8s 学分: %8f 成绩 : %8dn,studentsi.
14、kcbh3 , studentsi.kecheng3 , studentsi.Mark3, studentsi.mark3); printf( 平均成绩%10fn,studentsi.Average); /将学生信息从文件读出/ void IO_ReadInfo() FILE *fp; int i; if (fp=fopen(Database.txt,rb)=NULL) printf(文件为空!n); return; if (fread(&num,sizeof(int),1,fp)!=1) num=-1; else for(i=0;inum;i+) fread(&studentsi,sizeo
15、f(struct Student),1,fp); fclose(fp); /将学生信息写入文件/ void IO_WriteInfo() FILE *fp; int i; if (fp=fopen(Database.txt,wb)=NULL) printf(不能打开文件!n); return; if (fwrite(&num,sizeof(int),1,fp)!=1) printf(写入文件错误!n); for (i=0;inum;i+) if (fwrite(&studentsi,sizeof(struct Student),1,fp)!=1) printf(写入文件错误!n); fclose(fp); /主程序/ main() int choice; IO_ReadInfo(); /将学生信息写入文件/ while(1) /主菜单/ system (color e0); printf(n- 成绩记录簿-n); printf(1. 增加 n); printf(2. 求学生平均成绩n); printf(3. 删除 n); printf(4. 按姓名查询学生记录n); printf(5. 按平均成绩排序n); printf(6. 退出n); printf(请选择(1-6):); scanf(%d,&choice); switch(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 房产预订买卖合同范本
- 安徽省就业协议协议书
- 小型矿场托管合同范本
- 安全生产经营合同范本
- 执行委托代理合同范本
- 巴塞尔协议包含的合同
- 建房承包安全合同范本
- 工程泥工班组合同范本
- 工地围挡出租合同范本
- 螃蟹运瓜大班教案
- 低空智能-从感知推理迈向群体具身
- 2026届八省联考(T8联考)2026届高三年级12月检测训练生物试卷(含答案详解)
- 血液管理系统培训课件
- 四川省2025年高职单招职业技能综合测试(中职类)电子信息类试卷
- 2026贵州安创数智科技有限公司社会公开招聘119人笔试考试参考试题及答案解析
- 2025中原农业保险股份有限公司招聘67人参考笔试试题及答案解析
- 公安刑事案件办理课件
- 幼儿园重大事项社会稳定风险评估制度(含实操模板)
- 浅谈现代步行街的改造
- 2026年包头轻工职业技术学院单招职业适应性测试题库附答案
- 2025至2030中国应急行业市场深度分析及发展趋势与行业项目调研及市场前景预测评估报告
评论
0/150
提交评论