




已阅读5页,还剩5页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#include #include #include #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(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 Assortbynum(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 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: Aversumofeverystudent(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: Assortbynum( 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); 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(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(10.标准分析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;in;i+) scanf(%ld%s,&stui.num,); stui.sum=0; for(j=0;j0) stui.aver= m0 ? stui.sum/m : -1; void Aversumofeverystudent(STU stu,int n,int m) int i,j; for(i=0;in;i+) printf(学生 %d:总成绩: %.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;im;i+) sumi=0; for(j=0;j0?sumi/n:-1; printf(课程 %d:总成绩: %.1f,平均成绩: %.1fn,i+1,sumi,averi); void Sortbyscore(STU stu,int n,int m,int (*compare)(float a,float b)int i,j,k,t;for(i=0;in-1;i+) k=i; for(j=i+1;jn;j+) if(*compare)(stuj.sum,stuk.sum) k=j; if(k!=i) for(t=0;tm;t+) swapfloat(&stuk.scoret,&stui.scoret); swapfloat(&stuk.sum,&stui.sum); swapfloat(&stuk.aver,&stui.aver); swaplong(&stuk.num,&stui.num); swapchar(,); int Ascending(float a,float b) return ab;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(char 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;in-1;i+) k=i; for(j=i+1;jn;j+) if(stuj.numstuk.num) k=j; if(k!=i) for(t=0;tm;t+) swapfloat(&stuk.scoret,&stui.scoret); swapfloat(&stuk.sum,&stui.sum); 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;in-1;i+) for(j=i+1;jn;j+) if(strcmp(,)0) for(t=0;tm;t+) swapfloat(&stui.scoret,&stuj.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;in;i+) if(stui.num=num) printf(%ldt%st,stui.num,); for(j=0;jm;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(输入你所想要查找的姓名n); scanf(%s,name); for(i=0;in;i+) if(strcmp(,name)=0) printf(%ldt%st,stui.num,); for(j=0;jm;j+) printf(%.0ft,stui.scorej); printf(%.0ft%.0fn,stui.sum,stui.aver); return; printf(n查无此人 n);void StatisticAnlysis(STU stu, int n, int m) int i,j,total,t6; for(j=0;jm;j+) printf(学科:%d:n,j+1); memset(t,0,sizeof(t); for(i=0;i=0&stui.scorej60) t0+; else if(stui.scorej70) t1+; else if(stui.scorej80) t2+; else if(stui.scorej90) t3+; else if(stui.scorej100) 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+5)*10+9,(float)ti/n*100); void Printscore(STU stu, int n, int m) int i,j; for(i=0;in;i+) printf(%ldt%st,stui.num,); for(j=0;jm;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); exit(0); fprintf(fp,%dt%dn,n,m); for(i=0;in;i+) fprintf(fp,%10ld%10s,stui.num,); for(j=0;jm;j+) fprintf(fp,%12.0f,stui.scorej); fprintf(fp,%12.0f%12.0fn,stui.sum,stui.aver); fclose(fp);void Readfromfile(STU stu,int *n
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二、应用设计主题说课稿-2025-2026学年小学信息技术(信息科技)五年级上册电子工业版(宁夏)
- 2025年中国高纯硫酸钡行业市场分析及投资价值评估前景预测报告
- 口腔培训分享知识课件
- 2025年中国干式甜菜浆(颗粒)行业市场分析及投资价值评估前景预测报告
- 任务一 小果树 我来种说课稿-2023-2024学年小学劳动五年级下册浙教版《劳动》
- 2025年线下演出市场复苏后的演出市场品牌合作案例报告
- 实习安全知识培训课件
- 保养基础知识培训内容课件
- 3 当冲突发生时 第二课时 教学设计-道德与法治四年级下册统编版
- 2024秋五年级道德与法治上册 第三单元 我们的国土 我们的家园 6 我们神圣的国土说课稿 新人教版
- 2025浙江杭州市工会社会工作者招聘工作40人笔试模拟试题及答案解析
- 2025年镇江市中考英语试题卷(含答案及解析)
- 2025年云南省“爱我国防”知识竞赛考试题库150题(含答案)
- 《英语(第三版)》课件-Unit 3
- 2025年江西省高考生物试卷真题(含标准答案及解析)
- 2025-2026学年九年级英语上学期第一次月考 (江苏省连云港专用)原卷
- 2025年食品行业市场风险防范策略方案
- 电动消防排烟窗施工方案
- GB/T 25729-2010粮油机械撞击松粉机
- GB/T 13912-2020金属覆盖层钢铁制件热浸镀锌层技术要求及试验方法
- 2022年泰安市中考英语试题(含答案)
评论
0/150
提交评论