用c语言编写一个成绩管理系统.doc_第1页
用c语言编写一个成绩管理系统.doc_第2页
用c语言编写一个成绩管理系统.doc_第3页
用c语言编写一个成绩管理系统.doc_第4页
用c语言编写一个成绩管理系统.doc_第5页
免费预览已结束,剩余1页可下载查看

下载本文档

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

文档简介

程序说明:有N个学生,每个学生的数据包含学号(不重复)、姓名、三门课的成绩及平均成绩,试设计一学生成绩管理系统,使之能提供以下功能: (1)主菜单 学生成绩管理系统 1、 成绩录入 2、 成绩查询 3、 成绩统计 4、 退出 (2)各菜单项功能 成绩录入:输入学生的学号、姓名及三门课的成绩; 成绩查询:(至少一种查询方式)。 v 按学号查询学生记录。 v 查询不及格学生的记录。 成绩统计: v 计算学生的平均分; v 根据学生的平均分高低,对学生的数据进行排序后输出; v 对学生单科成绩排序,输出学生姓名与该科成绩; 退出系统:退出整个系统(即主菜单)。 (3)结构体数组: define N 30 struct student int num; /* 定义学号*/char name20; /* 定义姓名*/float score3; /* 定义存贮三门课成绩的数组*/float average; /* 定义平均成绩*/;struct student stuN; /* 定义结构体数组,存贮多个学生的记录*/. #include #include #include struct student int num; char name20; float score4; float average; stu10000; long t,max; bool unpass1000; FILE *fstu=fopen(stud.dat,at+); int init() int no,i; float s4,ave; char nam20; while (!feof(fstu) fscanf(fstu,%d,&no); fscanf(fstu,%s,nam); fscanf(fstu,%f%f%f%f,&s1,&s2,&s3,&ave); if (nomax) max=no; stuno.num=no; strcpy(,nam); unpassno=false; for (i=1;i=3;i+) stuno.scorei=si; if (simax) max=no; stuno.num=no; sum=0.0; strcpy(,nam); unpassno=false; for (i=1;i=3;i+) stuno.scorei=si; sum=sum+si; if (si60) unpassno=true; stuno.average=sum/3.0; fprintf(fstu,n); fprintf(fstu,%d %s %f %f %f %fn,stuno.num,,stuno.score1,stuno.score2,stuno.score3,stuno.average); int find(int x) long i,no; switch (x) case 1:printf(请输入学号:); scanf(%d,&no); printf(%d %s %f %f %f %fn,stuno.num,,stuno.score1, stuno.score2,stuno.score3,stuno.average); break; case 2:for (i=1;i=max;i+) if (unpassi) printf(%d %s %f %f %f %fn,stui.num,,stui.score1,stui.score2,stui.score3,stui.average); break; int sort(int x) extern int headprint(int x); student so1000; int i,j,k,n; switch (x) case 1:for (i=1;i=max;i+) if (stui.num=i) printf(%d %s %fn,i,,stui.average); break; case 2:n=0; for (i=1;istui.average)&(j=j;k-) sok=sok-1; soj=stui; for (i=1;i=n;i+) printf(%d %s %f %f %f %fn,soi.num,,soi.score1,soi.score2,soi.score3,soi.average); break; case 3:headprint(4); int othersort(int x) extern int headprint(int x); student so1000; int i,j,k,n,q; q=0; switch (x) case 1:if (q=0) q=1; case 2:if (q=0) q=2; case 3:if (q=0) q=3; n=0;for (i=1;istui.scoreq)&(j=j;k-) sok=sok-1; soj=stui; for (i=1;i=n;i+) printf(%d %s %fn,soi.num,,soi.scoreq); break; int select(int x) extern int headprint(int x); int p; switch (x) case 1:scanf(%d,&p); switch (p) case 1:stuinsert();break; case 2:headprint(2);break; case 3:headprint(3);break; case 4:t=0;break; break; case 2:scanf(%d,&p); find(p);break; case 3:scanf(%d,&p); sort(p);break; case 4:scanf(%d,&p); othersort(p);break; int headprint(int x) switch (x) case 1:printf(学生成绩管理系统n); printf(1、 成绩录入n); printf(2、 成绩查询n); printf(3、 成绩统计n); printf(4、 退出n); select(x); break; case 2:printf(1、 按学号查询学生记录n); printf(2、 查询不及格学生的记录n); select(x); break; case 3:printf(1、 计算学生的平均分n); printf(2、 根据学生的平均分高低,对学生的数据进行排序后输出n); printf(3、 对学生单科成绩排序,输出学生姓名与该科成绩n); select(x); break;

温馨提示

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

最新文档

评论

0/150

提交评论