學(xué)生成績管理系統(tǒng)v6.0_第1頁
學(xué)生成績管理系統(tǒng)v6.0_第2頁
學(xué)生成績管理系統(tǒng)v6.0_第3頁
學(xué)生成績管理系統(tǒng)v6.0_第4頁
學(xué)生成績管理系統(tǒng)v6.0_第5頁
已閱讀5頁,還剩4頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、#include #include #include #define m_l 10#define m_num 30#define m_cs 6typedef struct studentlong 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

2、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,

3、 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;p

4、rintf( 請輸入學(xué)生人數(shù)(n=%d):n,m_num);scanf(%d,&n);printf( 請輸入課程數(shù)目(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);Print

5、score( 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 學(xué)號升序排序n);Printscore( stu ,n, m);break;case 7:Sortbyname( stu , n, m); printf(n 姓名字典升序排序n);Printscore( stu ,n, m); break;case 8:Searchbynum( stu ,

6、n, m); break;case 9:Searchbyname( stu , n, m);break;case 10:StatisticAnlysis( stu , n, m);break;case 11:Printscore( stu ,n, m);break;Writetofile(stu,n,m);break;case 12:Readfromfile(stu,&n,&m);break;case 0:printf(n 歡迎下次繼續(xù)使用 );exit(0);default:printf(n 輸入錯誤 );return 0;int menu(void)int items;printf( 歡迎

7、使用學(xué)生成績管理系統(tǒng)n);printf(1. 輸入成績 n);printf(2. 計算各個學(xué)生總成績和平均成績n);printf(3. 計算各門學(xué)科總成績和平均成績n);printf(4. 成績降序排序n);printf(5. 成績升序排序n);printf(6. 學(xué)號升序排序n);printf(7. 姓名升序排序n);printf(8. 通過學(xué)號查找成績n);printf(9. 通過姓名查找成績n);printf(10.標(biāo)準(zhǔn)分析n);printf(11.顯示成績n);printf(12.寫入文件n);printf(13.讀取文件n);printf(0. 退出 n);printf( 請做出您的

8、選擇n);scanf(%d,&items);return items;void Readscore(STU stu,int n,int m)int i,j;printf( 請輸入學(xué)生學(xué)號,姓名,成績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(學(xué)生 d:總成績:.1f 平均成績:.mn

9、,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+

10、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)

11、 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(&

12、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,&

13、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( 輸入你所想要查找的學(xué)號n);scanf(%ld,&num);for(i=0;in;i+)if(stui.num=num)printf(%ldt%st,stui.num,);for(

14、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(%.0f

15、t,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( 學(xué)科: %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)

16、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);elseprintf(%d-%dt%dt%.2f%n,ti,(i+5)*10,(i+5)*10+9,(float)ti/n*100);void Printscore(STU stu,

17、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. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論