版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、/成绩管理系统v1.0 / 能动1302 王清栋 1306030217#include #include #define N 30#define M 6void Input (long num,int scoreM,int n,int m);void Totalave (int scoreM,int n,int m);void evestuTotalave (int scoreM,int n,int m,long num);void Scoredes (long num,int scoreM,int n,int m);void Scoreas (long num,int scoreM,int
2、n,int m);void Numas (long num,int scoreM,int n,int m);void Search (long num,int scoreM,int n,int x,int m);void statistis (long num,int scoreM,int n,int m);void List (long num,int scoreM,int n,int m);int main() int n,scoreNM,c,x,m; long numN; printf(输入学生人数); scanf(%d,&n); printf(输入考试科目); scanf(%d,&m)
3、; printf(1.Input recordn); printf(2.Caculate totel and average score of every coursen); printf(3.Caculate totel and average score of every studentn); printf(4.Sort in descending order by total score of every studentn); printf(5.Sort in ascending order by total score of every studentn); printf(6.Sort
4、 in ascending order by numbern); printf(7.Search by numbern); printf(8.Statistic analysis for every coursen); printf(9.List recordn); printf(0.Exitn); printf(Please enter your choice:n); printf(n); for(;) scanf(%d,&c); switch(c) case 1: /录入学生学号和各科成绩 Input (num,score,n,m); printf(Please enter your ch
5、oice:n); break; case 2: /计算每门课程的总分和平均分 Totalave (score,n,m); printf(Please enter your choice:n); break; case 3: /计算每个学生的总分和平均分 evestuTotalave (score,n,m,num); break; case 4: /按每个学生的总分由高到低排出名次表 Scoredes (num,score,n,m); printf(Please enter your choice:n); break; case 5: /按每个学生的总分由低到高排出名次表 Scoreas (nu
6、m,score,n,m); printf(Please enter your choice:n); break; case 6: /按学号由小到大排出名次表 Numas (num,score,n,m); printf(Please enter your choice:n); break; case 7: /按学号查询学生排名及其各科成绩 printf(请输入查找学号n); scanf(%d,&x); Search (num,score,n,x,m); printf(Please enter your choice:n); break; case 8: /成绩分析 所占百分比 statistis
7、 (num,score,n,m); printf(Please enter your choice:n); break; case 9: /全部输出 List (num,score,n,m); Totalave (score,n,m); printf(Please enter your choice:n); break; case 0: exit(0); return 0;void Input (long num,int scoreM,int n,int m) /1 int i,j; for(i=0;in;i+) printf(Input students ID and score); sca
8、nf(%ld,&numi); for(j=0;jm;j+) scanf(%d,&scoreij); void Totalave (int scoreM,int n,int m) /2.计算每门课程的总分和平均分 int i,j,sumM; double aveM; for(j=0;jm;j+) sumj=0; for(i=0;in;i+) sumj=sumj+scoreij; avej=(double)sumj/n; for(i=0;im;i+) printf(科目%d的总分=%d,课程的平均分=%fn,i+1,sumi,avei);void evestuTotalave (int score
9、M,int n,int m,long num) /3.计算每个学生的总分和平均分 int i,j,sumN; double aveN; for(i=0;in;i+) sumi=0; for(j=0;jm;j+) sumi=sumi+scoreij; avei=(double)sumi/m; for(i=0;in;i+) printf(学号为%ld的总分=%d,其平均分=%fn,numi,sumi,avei);void Scoredes (long num,int scoreM,int n,int m) /4.按每个学生的总分由高到低排出名次表 int i,j,k,t,h,sumN; for(i
10、=0;in;i+) sumi=0; for(j=0;jm;j+) sumi=sumi+scoreij; for(i=0;in;i+) k=i; for(j=i+1;jsumk) k=j; if(i!=k) t=sumk,h=numk; sumk=sumi,numk=numi; sumi=t,numi=h; for(i=0;in;i+) printf(ID:%10ld,score:%dn,numi,sumi);/以长整形打印用%ldvoid Scoreas (long num,int scoreM,int n,int m) /5.按每个学生的总分由di到gao排出名次表 int i,j,k,t,
11、h,sumN; for(i=0;in;i+) sumi=0; for(j=0;jm;j+) sumi=sumi+scoreij; for(i=0;in;i+) k=i; for(j=i+1;jn;j+) if (sumjsumk) k=j; if(i!=k) t=sumk,h=numk; sumk=sumi,numk=numi; sumi=t,numi=h; for(i=0;in;i+) printf(ID:%10ld,score:%dn,numi,sumi);/以长整形打印用%ldvoid Numas (long num,int scoreM,int n,int m) /6.按学号由小到大排
12、出名次表 int i,j,k,tM,h,l; for(i=0;in;i+) k=i; for(j=i+1;jn;j+) if (numjnumk) k=j; if(i!=k) h=numk; numk=numi; numi=h; for(l=0;lm;l+) tl=scorekl; scorekl=scoreil; scoreil=tl; for(i=0;in;i+) printf(ID:%10ldn,numi);/以长整形打印用%ld for(j=0;jm;j+) printf(project %d score:%dn,j+1,scoreij); void Search (long num,
13、int scoreM,int n,int x,int m) /7.按学号查询学生排名及其各科成绩 int high=n-1,low=0,mid,c=1,pos,o,find=0,i,j,k,tM,h,sumN,l; for(i=0;in;i+) sumi=0; for(j=0;jm;j+) sumi=sumi+scoreij; for(i=0;in;i+) k=i; for(j=i+1;jn;j+) if (numjnumk) k=j; if(i!=k) h=numk,o=sumk; numk=numi,sumk=sumi; numi=h,sumi=o; for(l=0;lm;l+) tl=s
14、corekl; scorekl=scoreil; scoreil=tl; while(find=0&lownummid) low=mid+1; else if(xnummid) high=mid-1; else pos=mid; find=1; if(find=0) printf(not findn); else for(i=0;isumpos) c+; printf(ID:%10ldn,numpos);/以长整形打印用%ld for(j=0;jm;j+) printf(project %d score:%dn,j+1,scoreposj); printf(all score: %d,orde
15、r:%dn,sumpos,c); void statistis (long num,int scoreM,int n,int m) /8. int a=0,b=0,c=0,d=0,e=0,i,j; double A,B,C,D,E; for(j=0;jm;j+) for(i=0;i=90) a+; else if(scoreij=80) b+; else if(scoreij=70) c+; else if(scoreij=60) d+; else e+; A=(double)a/n*100; B=(double)b/n*100; C=(double)c/n*100; D=(double)d/n*100; E=(double)e/n*100; printf(project %dn,j+1); printf(优秀人数%d,百分比:%f%n,a,A); printf(良好人数%d,百分比:%f%n,b,B); printf(中等人数%d,百分比:%f%n,c,C); printf(及格人数%d,百分比:%f%n,d,D); printf(不及格人数%d,百分比:%f%n,e,E); void List (long
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026年四川城市职业学院单招职业技能考试模拟试题含详细答案解析
- 2026年宁德职业技术学院高职单招职业适应性测试备考试题及答案详细解析
- 2026浙江衢州市卫生健康委员会衢州市第三医院招聘第一批编外人员3人参考考试题库及答案解析
- 2026年安徽中澳科技职业学院单招综合素质考试模拟试题含详细答案解析
- 2026年浙江建设职业技术学院高职单招职业适应性测试备考题库及答案详细解析
- 2026重庆日报报业集团所属企业招聘2人参考考试试题及答案解析
- 2026年湛江幼儿师范专科学校高职单招职业适应性测试模拟试题及答案详细解析
- 2026年金肯职业技术学院高职单招职业适应性测试备考试题及答案详细解析
- 2026年成都银杏酒店管理学院单招职业技能考试模拟试题含详细答案解析
- 2026年辽宁轨道交通职业学院单招综合素质考试参考题库含详细答案解析
- 新《增值税法实施条例》逐条解读课件
- 2026年广西职教高考5套语文模拟试卷试题及逐题答案解释和5套试题的综合分析报告
- 领导干部任职前廉政法规知识测试题及答案(2025年)
- 内分泌急症识别与应急护理预案
- 急危重症患者气道管理新进展
- 心包填塞的表现与护理
- 青霉素皮试及过敏试验相关知识考核试题与答案
- 军人岗位奉献课件
- 钢材销售年终工作总结
- 腱鞘囊肿护理查房
- T/ZGZS 0302-2023再生工业盐氯化钠
评论
0/150
提交评论