版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上#include <stdio.h>#include <stdlib.h>#include <string.h>#define m_l 10#define m_num 30#define m_cs 6typedef struct student long num ; char namem_l; float scorem_cs; float sum; float aver;STU;int menu(void);void Readscore(STU stu,int n,int m);void Aversumofeverystudent(
2、STU stu,int n,int m);void Aversumofeverycourse(STU stu,int n,int m);void Sortbyscore(STU stu,int n,int m,int (*compare)(float a,float b);int Ascending(float a,float b);int Descending(float a,float b);void swapfloat(float *x,float *y);void swaplong(long *x,long *y);void swapchar(char x,char y);void A
3、ssortbynum(STU stu, int n, int m);void Sortbyname(STU stu, int n, int m);void Searchbynum(STU stu, int n, int m);void Searchbyname(STU stu, int n, int m);void StatisticAnlysis(STU stu, int n, int m);void Printscore(STU stu, int n, int m);void Writetofile(STU stu, int n, int m);void Readfromfile(STU
4、stu, int *n, int *m);int main() char ch; int n=0,m=0; STU stum_num; printf("请输入学生人数(n<=%d):n",m_num); scanf("%d",&n); printf("请输入课程数目(m<=%d):n",m_cs); scanf("%d",&m); while(1) ch=menu(); switch(ch) case 1: Readscore(stu,n,m); break; case 2: Avers
5、umofeverystudent(stu ,n,m); break; case 3: Aversumofeverycourse(stu ,n,m); break; case 4: Sortbyscore(stu ,n,m,Descending); printf("n成绩降序排序n"); Printscore( stu ,n, m); break; case 5: Sortbyscore(stu ,n,m,Ascending); printf("n成绩升序排序n"); Printscore( stu ,n, m); break; case 6: Assor
6、tbynum( stu , n, m); printf("n学号升序排序n"); Printscore( stu ,n, m); break; case 7: Sortbyname( stu , n, m); printf("n姓名字典升序排序n"); Printscore( stu ,n, m); break; case 8: Searchbynum( stu , n, m); break; case 9: Searchbyname( stu , n, m); break; case 10: StatisticAnlysis( stu , n, m);
7、 break; case 11: Printscore( stu ,n, m); break; case 12: Writetofile(stu,n,m); break; case 13: Readfromfile(stu,&n,&m); break; case 0: printf("n欢迎下次继续使用"); exit(0); default: printf("n输入错误"); return 0;int menu(void) int items; printf("欢迎使用学生成绩管理系统n"); printf(&quo
8、t;1.输入成绩n"); printf("2.计算各个学生总成绩和平均成绩n"); printf("3.计算各门学科总成绩和平均成绩n"); printf("4.成绩降序排序n"); printf("5.成绩升序排序n"); printf("6.学号升序排序n"); printf("7.姓名升序排序n"); printf("8.通过学号查找成绩n"); printf("9.通过姓名查找成绩n"); printf("1
9、0.标准分析n"); printf("11.显示成绩n"); printf("12.写入文件n"); printf("13.读取文件n"); printf("0.退出n"); printf("请做出您的选择n"); scanf("%d",&items); return items;void Readscore(STU stu,int n,int m) int i,j; printf("请输入学生学号,姓名,成绩n"); for(i=0;i
10、<n;i+) scanf("%ld%s",&stui.num,); stui.sum=0; for(j=0;j<m;j+) scanf("%f",&stui.scorej); stui.sum+=stui.scorej; if(m>0) stui.aver= m>0 ? stui.sum/m : -1; void Aversumofeverystudent(STU stu,int n,int m) int i,j; for(i=0;i<n;i+) printf("学生 %d:总成绩
11、: %.1f,平均成绩: %.1fn",i+1,stui.sum,stui.aver); void Aversumofeverycourse(STU stu,int n,int m) int i,j; float summ_cs,averm_cs; for(i=0;i<m;i+) sumi=0; for(j=0;j<n;j+) sumi+=stuj.scorei; averi= n>0?sumi/n:-1; printf("课程 %d:总成绩: %.1f,平均成绩: %.1fn",i+1,sumi,averi); void Sortbyscore
12、(STU stu,int n,int m,int (*compare)(float a,float b)int i,j,k,t;for(i=0;i<n-1;i+) k=i; for(j=i+1;j<n;j+) if(*compare)(stuj.sum,stuk.sum) k=j; if(k!=i) for(t=0;t<m;t+) swapfloat(&stuk.scoret,&stui.scoret); swapfloat(&stuk.sum,&stui.sum); swapfloat(&stuk.aver,&stui.ave
13、r); swaplong(&stuk.num,&stui.num); swapchar(,); int Ascending(float a,float b) return a<b;int Descending(float a,float b) return a>b;void swapfloat(float *x,float *y) float b; b=*x; *x=*y; *y=b;void swaplong(long *x,long *y) long b; b=*x; *x=*y; *y=b;void swapchar(cha
14、r x,char y) char bm_l; strcpy(b,x); strcpy(x,y); strcpy(y,b);void Assortbynum(STU stu, int n, int m) int i,j,k,t;for(i=0;i<n-1;i+) k=i; for(j=i+1;j<n;j+) if(stuj.num<stuk.num) k=j; if(k!=i) for(t=0;t<m;t+) swapfloat(&stuk.scoret,&stui.scoret); swapfloat(&stuk.sum,&stui.su
15、m); swapfloat(&stuk.aver,&stui.aver); swaplong(&stuk.num,&stui.num); swapchar(,); void Sortbyname(STU stu, int n, int m) int i,j,t; for(i=0;i<n-1;i+) for(j=i+1;j<n;j+) if(strcmp(,)<0) for(t=0;t<m;t+) swapfloat(&stui.scoret,&stuj
16、.scoret); swapfloat(&stuj.sum,&stui.sum); swapfloat(&stuj.aver,&stui.aver); swaplong(&stuj.num,&stui.num); swapchar(,); void Searchbynum(STU stu, int n, int m) long num; int i,j; printf("输入你所想要查找的学号n"); scanf("%ld",&num); for(i=0;i<
17、;n;i+) if(stui.num=num) printf("%ldt%st",stui.num,); for(j=0;j<m;j+) printf("%.0ft",stui.scorej); printf("%.0ft%.0fn",stui.sum,stui.aver); return; printf("n查无此号 n");void Searchbyname(STU stu, int n, int m) char namem_l; int i,j; printf("输入你所想要
18、查找的姓名n"); scanf("%s",name); for(i=0;i<n;i+) if(strcmp(,name)=0) printf("%ldt%st",stui.num,); for(j=0;j<m;j+) printf("%.0ft",stui.scorej); printf("%.0ft%.0fn",stui.sum,stui.aver); return; printf("n查无此人 n");void StatisticAn
19、lysis(STU stu, int n, int m) int i,j,total,t6; for(j=0;j<m;j+) printf("学科:%d:n",j+1); memset(t,0,sizeof(t); for(i=0;i<n;i+) if(stui.scorej>=0&&stui.scorej<60) t0+; else if(stui.scorej<70) t1+; else if(stui.scorej<80) t2+; else if(stui.scorej<90) t3+; else if(st
20、ui.scorej<100) t4+; else if(stui.scorej=100) t5+; total=0; for(i=0;i<=5;i+) total+=ti; for(i=0;i<=5;i+) if(i=0) printf("<60t%dt%.2f%n",ti,(float)ti/n*100); else if(i=5) printf("=100t%dt%.2f%n",ti,(float)ti/n*100); else printf("%d-%dt%dt%.2f%n",ti,(i+5)*10,(i
21、+5)*10+9,(float)ti/n*100); void Printscore(STU stu, int n, int m) int i,j; for(i=0;i<n;i+) printf("%ldt%st",stui.num,); for(j=0;j<m;j+) printf("%.1ft",stui.scorej); printf("%.1ft%.1fn",stui.sum,stui.aver); void Writetofile(STU stu, int n, int m) FILE *fp; int i,j; if(fp=fopen("student.txt","w")=NULL) printf("打开 “student.txt”失败!n
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 租房合同怎样代签字(3篇)
- 2025标准个人车辆抵押借款合同协议书
- 2025建筑行业借款合同范本
- 2025年多人合伙人合同范本
- 2025年版个人房屋买卖合同协议书范本
- 2025租赁合同范本模板参考
- 2025年道路运输企业安全生产管理人员上岗证题及答案
- 笛子创意画课件
- 淮安客运上岗证模拟考试题库及答案
- 2025私营企业劳动合同书模板样本
- 成品化粪池施工方案
- 山西省三晋联盟山西名校2024-2025学年高二上学期11月期中联合考试 化学试题
- 藏毛窦的治疗及护理
- 农村集体经济组织内部控制制度
- 药品经营质量管理规范
- 通信工程勘察设计管理办法
- 婴幼儿发展引导员(育婴员)职业技能竞赛理论考试题库(含答案)
- 公安涉警舆情课件
- 品三国论领导艺术智慧树知到期末考试答案2024年
- 2024年安徽省电力行业无人机巡检技能竞赛考试参考题库(含答案)
- 渭南好运旺塑业有限公司农用灌溉设施生产项目环境影响报告
评论
0/150
提交评论