




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上#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("請(qǐng)輸入學(xué)生人數(shù)(n<=%d):n",m_num); scanf("%d",&n); printf("請(qǐng)輸入課程數(shù)目(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成績(jī)降序排序n"); Printscore( stu ,n, m); break; case 5: Sortbyscore(stu ,n,m,Ascending); printf("n成績(jī)升序排序n"); Printscore( stu ,n, m); break; case 6: Assor
6、tbynum( stu , n, m); printf("n學(xué)號(hào)升序排序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歡迎下次繼續(xù)使用"); exit(0); default: printf("n輸入錯(cuò)誤"); return 0;int menu(void) int items; printf("歡迎使用學(xué)生成績(jī)管理系統(tǒng)n"); printf(&quo
8、t;1.輸入成績(jī)n"); printf("2.計(jì)算各個(gè)學(xué)生總成績(jī)和平均成績(jī)n"); printf("3.計(jì)算各門學(xué)科總成績(jī)和平均成績(jī)n"); printf("4.成績(jī)降序排序n"); printf("5.成績(jī)升序排序n"); printf("6.學(xué)號(hào)升序排序n"); printf("7.姓名升序排序n"); printf("8.通過(guò)學(xué)號(hào)查找成績(jī)n"); printf("9.通過(guò)姓名查找成績(jī)n"); printf("1
9、0.標(biāo)準(zhǔn)分析n"); printf("11.顯示成績(jī)n"); printf("12.寫入文件n"); printf("13.讀取文件n"); printf("0.退出n"); printf("請(qǐng)做出您的選擇n"); scanf("%d",&items); return items;void Readscore(STU stu,int n,int m) int i,j; printf("請(qǐng)輸入學(xué)生學(xué)號(hào),姓名,成績(jī)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("學(xué)生 %d:總成績(jī)
11、: %.1f,平均成績(jī): %.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:總成績(jī): %.1f,平均成績(jī): %.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("輸入你所想要查找的學(xué)號(hào)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查無(wú)此號(hào) 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查無(wú)此人 n");void StatisticAn
19、lysis(STU stu, int n, int m) int i,j,total,t6; for(j=0;j<m;j+) printf("學(xué)科:%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”失?。
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 子宮脫垂培訓(xùn)課件
- 委員履職基礎(chǔ)知識(shí)培訓(xùn)課件
- 好玩的玩具課件
- 女性私護(hù)課件
- 2025年城市地下綜合管廊建設(shè)項(xiàng)目資金申請(qǐng)與施工安全評(píng)估報(bào)告
- 法院防汛減災(zāi)方案(3篇)
- 中國(guó)大模型技術(shù)的創(chuàng)新路徑與發(fā)展趨勢(shì)研究
- 人工智能技術(shù)在智能人力資源員工關(guān)懷中的應(yīng)用與員工滿意度提高
- 2025年中小學(xué)教師師德理論考試試題及答案(版)
- 個(gè)人股東轉(zhuǎn)讓協(xié)議書范本
- 山東省濟(jì)南市歷城區(qū)2023-2024學(xué)年八年級(jí)下學(xué)期期末考試英語(yǔ)試題(含答案)
- 濱州傳媒集團(tuán)考試題庫(kù)及答案
- T/CBMCA 007-2019合成樹脂瓦
- 銷售合同合規(guī)培訓(xùn)
- 道路養(yǎng)護(hù)協(xié)議書范本
- 支付結(jié)算人行題庫(kù)及答案
- 《城市更新的》課件
- 2024-2030全球商業(yè)電子垃圾回收行業(yè)調(diào)研及趨勢(shì)分析報(bào)告
- 會(huì)議活動(dòng)風(fēng)險(xiǎn)管理研究-全面剖析
- 機(jī)械傳動(dòng)知識(shí)課件2
- 2025年度運(yùn)輸業(yè)安全生產(chǎn)知識(shí)競(jìng)賽試題(附答案)
評(píng)論
0/150
提交評(píng)論