C語(yǔ)言課程設(shè)計(jì)報(bào)告學(xué)生成績(jī)的管理系統(tǒng)_第1頁(yè)
C語(yǔ)言課程設(shè)計(jì)報(bào)告學(xué)生成績(jī)的管理系統(tǒng)_第2頁(yè)
C語(yǔ)言課程設(shè)計(jì)報(bào)告學(xué)生成績(jī)的管理系統(tǒng)_第3頁(yè)
C語(yǔ)言課程設(shè)計(jì)報(bào)告學(xué)生成績(jī)的管理系統(tǒng)_第4頁(yè)
C語(yǔ)言課程設(shè)計(jì)報(bào)告學(xué)生成績(jī)的管理系統(tǒng)_第5頁(yè)
已閱讀5頁(yè),還剩19頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、-. z.信息技術(shù)工程學(xué)院C語(yǔ)言課程設(shè)計(jì)報(bào)告題目:學(xué)生成績(jī)管理系統(tǒng)student achievement management system目錄 TOC o 1-3 h z u HYPERLINK l _Toc438823722一設(shè)計(jì)目的 PAGEREF _Toc438823722 h 3HYPERLINK l _Toc438823723二課程設(shè)計(jì)的容 PAGEREF _Toc438823723 h 3HYPERLINK l _Toc438823724三課程設(shè)計(jì)的要求與數(shù)據(jù) PAGEREF _Toc438823724 h 3HYPERLINK l _Toc438823725四課程設(shè)計(jì)應(yīng)完成的工

2、作 PAGEREF _Toc438823725 h 3HYPERLINK l _Toc438823726五總體設(shè)計(jì)包含幾大功能模塊 PAGEREF _Toc438823726 h 3HYPERLINK l _Toc438823727六詳細(xì)設(shè)計(jì) PAGEREF _Toc438823727 h 3HYPERLINK l _Toc4388237286.1各個(gè)模塊的功能和實(shí)現(xiàn) PAGEREF _Toc438823728 h 3HYPERLINK l _Toc4388237296.2 流程圖 PAGEREF _Toc438823729 h 3HYPERLINK l _Toc438823730管理員模式流

3、程圖 PAGEREF _Toc438823730 h 3HYPERLINK l _Toc438823731來(lái)賓模式流程圖 PAGEREF _Toc438823731 h 1HYPERLINK l _Toc438823732 PAGEREF _Toc438823732 h 1HYPERLINK l _Toc438823733七調(diào)試分析各模塊測(cè)試結(jié)果 PAGEREF _Toc438823733 h 3HYPERLINK l _Toc4388237347.1源代碼 PAGEREF _Toc438823734 h 3HYPERLINK l _Toc4388237357.2 各模塊測(cè)試結(jié)果 PAGERE

4、F _Toc438823735 h 3HYPERLINK l _Toc438823736八總結(jié) PAGEREF _Toc438823736 h 3HYPERLINK l _Toc438823737九參考資料 PAGEREF _Toc438823737 h 3一設(shè)計(jì)目的通過(guò)本課程設(shè)計(jì)穩(wěn)固C語(yǔ)言程序設(shè)計(jì)課程的教學(xué)成果,深入理解構(gòu)造體、指針、鏈表、動(dòng)態(tài)分配存和文件操作的等C程序設(shè)計(jì)中的中高級(jí)技術(shù),通過(guò)課程設(shè)計(jì)的綜合訓(xùn)練,培養(yǎng)學(xué)生實(shí)際分析問(wèn)題、編程和動(dòng)手能力、提高學(xué)生利用C語(yǔ)言進(jìn)展程序設(shè)計(jì)的能力,初步培養(yǎng)良好的編程習(xí)慣和編程風(fēng)格,初步學(xué)習(xí)程序的文檔的撰寫(xiě)方法。二課程設(shè)計(jì)的容通過(guò)C語(yǔ)言程序系統(tǒng),設(shè)計(jì)一個(gè)

5、可以對(duì)學(xué)生的成績(jī)信息進(jìn)展管理的程序,其中學(xué)生的信息可以包括:*、各科目的成績(jī)的平均分排序等,其功能可以包括學(xué)生成績(jī)的輸入、輸出、查詢、排序、刪除、統(tǒng)計(jì)、退出等。三課程設(shè)計(jì)的要求與數(shù)據(jù)1、用C語(yǔ)言實(shí)現(xiàn)系統(tǒng);2、對(duì)學(xué)生信息(包括*、語(yǔ)文、數(shù)學(xué)、英語(yǔ)、平均分)進(jìn)展管理,包括學(xué)生成績(jī)的信息輸入、輸出、查詢、刪除、排序、統(tǒng)計(jì)、退出、顯示,以及整個(gè)程序的切換登錄模式和修改管理員的信息.3、學(xué)生信息包括:(1)、每一條記錄包括一個(gè)學(xué)生的*、3門課成績(jī)(2)、成績(jī)信息錄入功能:(成績(jī)信息用文件保存,可以一次完成假設(shè)干條記錄的輸入。)(3)、成績(jī)信息顯示瀏覽功能:完成全部學(xué)生記錄的顯示。(4)、查詢功能:完成按

6、查找學(xué)生記錄,并顯示。(5)、成績(jī)信息的刪除:按*進(jìn)展刪除*學(xué)生的成績(jī).(6)、排序功能:按學(xué)生平均成績(jī)進(jìn)展排序。(7)、應(yīng)提供一個(gè)界面來(lái)調(diào)用各個(gè)功能,調(diào)用界面和各個(gè)功能的操作界面應(yīng)盡可能清晰美觀!四課程設(shè)計(jì)應(yīng)完成的工作(1)編寫(xiě)算法;(2)算法測(cè)試,并有具體的測(cè)試結(jié)果和結(jié)果分析;(3)撰寫(xiě)課程設(shè)計(jì)報(bào)告。容包括:封面扉頁(yè)設(shè)計(jì)任務(wù)書(shū)目錄總體設(shè)計(jì)方案包括流程圖使用說(shuō)明及運(yùn)行實(shí)例包括界面成員設(shè)計(jì)容簡(jiǎn)介工程源程序代碼注意注釋的使用指導(dǎo)教師評(píng)語(yǔ)五總體設(shè)計(jì)包含幾大功能模塊1、成績(jī)錄入功能2、成績(jī)輸出功能3、成績(jī)查詢功能4、刪除模塊 5、排序功能 6、統(tǒng)計(jì)功能 7、退出系統(tǒng)六詳細(xì)設(shè)計(jì)6.1各個(gè)模塊的功能和實(shí)

7、現(xiàn)1整個(gè)成績(jī)管理系統(tǒng)設(shè)計(jì)分為9個(gè)模塊:1.輸入學(xué)生成績(jī)2.刪除學(xué)生成績(jī)3.查詢學(xué)生成績(jī)4.修改學(xué)生成績(jī)5.排序?qū)W生成績(jī)6.保存記錄7.顯示所有8.退出系統(tǒng)9.修改管理員信息2主要函數(shù)的功能 1.主函數(shù)main():定義學(xué)生構(gòu)造體數(shù)組,調(diào)用錄入,統(tǒng)計(jì)等函數(shù)對(duì)成績(jī)表進(jìn)展處理。 2.輸入數(shù)據(jù)函數(shù)input():輸入*、成績(jī)。 3排序函數(shù)sort():對(duì)總成績(jī)或者平均成績(jī),進(jìn)展排序,按從高到低或者從低到高。 4.顯示數(shù)據(jù)函數(shù)display():顯示各個(gè)學(xué)生的總成績(jī) 5新增數(shù)據(jù)函數(shù)insert():增加學(xué)生學(xué)生記錄。6.刪除數(shù)據(jù)函數(shù)del():由于各種原因,刪除*些同學(xué)的成績(jī)、*等。7.平均值函數(shù)ave

8、rage():求各個(gè)同學(xué)總成績(jī)的平均值。8.查詢數(shù)據(jù)函數(shù)qur():查詢學(xué)生的信息。9.保存數(shù)據(jù)函數(shù)save():再一次翻開(kāi)界面是,仍有上次所找的訊息。10.退出系統(tǒng)函數(shù)e*it():當(dāng)要退出整個(gè)系統(tǒng)時(shí)。6.2 流程圖管理員模式流程圖輸出菜單輸入 根據(jù)菜單輸入n的值選擇程序完畢開(kāi)場(chǎng)保存查找退出刪除統(tǒng)計(jì)插入排序輸出開(kāi)場(chǎng)來(lái)賓模式流程圖輸出菜單根據(jù)菜單,選擇程序退出程序切換登錄排序成績(jī)顯示成績(jī)查詢成績(jī)完畢七調(diào)試分析各模塊測(cè)試結(jié)果7.1源代碼#include#include#include#include#include#define HEADER2 *數(shù)學(xué)英語(yǔ) C語(yǔ)言總分平均分n#define FO

9、RMAT %s %s %d %d %d %d %.2fn#define DATA p-data.num,,p-data.mgrade,p-data.egrade,p-data.cgrade,p-data.total,p-data.aveint saveflag=0;typedef unsigned short WORD;struct student char num10; char name15; int mgrade; int egrade; int cgrade; int total; float ave;typedef struct node struct stud

10、ent data; struct node *ne*t;Node,*Link;void menu() time_t now; now=time(NULL); printf( 學(xué)生成績(jī)管理系統(tǒng) n); printf(n); printf( *n); printf( * *n); printf( * 1 輸入成績(jī) 2 刪除成績(jī) *n); printf( * *n); printf( * 3 查詢成績(jī) 4 修改成績(jī) *n); printf( * *n); printf( * 5 排序成績(jī) 6 保存記錄 *n); printf( * *n); printf( * 7 顯示所有 0 退出系統(tǒng) *n);

11、printf( * *n); printf( *n); printf( * 8 切換登錄模式 9 修改管理員信息 *n); printf( *n); printf(n 請(qǐng)你選擇操作命令前的的數(shù)字(09):);int menu2() /int select; time_t now; now=time(NULL); system(cls); /清屏 printf(n學(xué)生模式nnn); printf( 學(xué)生成績(jī)管理系統(tǒng) n); printf(n); printf( *n); printf( * *n); printf( * 1 查詢成績(jī) 2 排序成績(jī) *n); printf( * *n); prin

12、tf( * 3 顯示所有 0 退出系統(tǒng) *n); printf( * *n); printf( *n); printf( * 4 切換登錄模式 *n); printf( *n); printf(n 請(qǐng)你選擇操作命令前的數(shù)字(04):); return 0;void printheader() printf(HEADER2);void printdata(Node *pp) Node *p;p=pp; printf(FORMAT,DATA);void Wrong()printf(nnnn*錯(cuò)誤:輸入不合法!*an);getch();void Nofind()printf(n沒(méi)有該學(xué)生!n);No

13、de* locate(Link l,char findmess,char nameornum) Node *r; if(strcmp(nameornum,num)=0) r=l-ne*t; while(r) if(strcmp(r-data.num,findmess)=0) return r; r=r-ne*t; else if(strcmp(nameornum,name)=0) r=l-ne*t; while(r) if(strcmp(,findmess)=0) return r; r=r-ne*t; return 0;void stringinput(char*t,i

14、nt lens,char*notice) char n225; do printf(notice); scanf(%s,n); if(strlen(n)lens) printf(n超出寬度!n);while(strlen(n)lens);strcpy(t,n); int numberinput(char *notice)int t=0; do printf(notice); scanf(%d,&t); if(t100|t100|tne*t; if(!p) printf(n目前無(wú)學(xué)生成績(jī)記錄!n); getch(); return; printf(nn); printheader(); whil

15、e(p) printdata(p); p=p-ne*t;/移至下一個(gè)結(jié)點(diǎn) void Add(Link l)/printf(增加學(xué)生記錄模塊n);/system(PAUSE); Node *p,*r,*s;char ch,flag=0,num10;r=l;system(cls);Disp(l);/先打印已有的學(xué)生信息while(r-ne*t!=NULL)r=r-ne*t;/將只指針移至鏈表末尾,準(zhǔn)備添加記錄while(1)/一次可輸入條記錄,直至輸入的*我0的記錄節(jié)點(diǎn)添加操作s=l-ne*t;while(1)stringinput(num,10,*(按0退出):);flag=0;if(strcm

16、p(num,0)=0)return;s=l-ne*t;while(s)/查詢*是否存在,假設(shè)存在則要求重新輸入if(strcmp(s-data.num,num)=0)flag=1; break;s=s-ne*t;if(flag=1)/提示用戶是否重新輸入getchar();printf(=*%s已存在,是否重新輸入(y/n)a:,num);scanf(%c,&ch);if(ch=y|ch=Y)continue;elsereturn ;elsebreak;p=(Node *)malloc(sizeof(Node);strcpy(p-data.num,num);/將字符串mun拷貝到p-data.

17、num中stringinput(,15,name:);p-data.cgrade=numberinput(c語(yǔ)言0-100:); p-data.mgrade=numberinput(數(shù)學(xué)0-100:); p-data.egrade=numberinput(英語(yǔ)0-100:);p-data.total=p-data.cgrade+p-data.mgrade+p-data.egrade;p-data.ave=(float)(p-data.total/3);p-ne*t=NULL;while(r-ne*t!=NULL)r=r-ne*t;r-ne*t=p;saveflag=1;v

18、oid Del(Link l) / printf(刪除學(xué)生記錄模塊n);/system(PAUSE); int sel;Node *p,*r;char findmess20;if(!l-ne*t)system(cls);printf(n=暫無(wú)學(xué)生記錄!n);getch();return;system(cls);Disp(l);printf(n 1通過(guò)*刪除 2通過(guò)刪除n);printf( 請(qǐng)選擇1,2);scanf(%d,&sel);if(sel=1)stringinput(findmess,10,請(qǐng)輸入*:);p=locate(l,findmess,num);if(p)r=l;while(r

19、-ne*t!=p)r=r-ne*t;r-ne*t=p-ne*t;free(p);/釋放存空間printf(n刪除成功!n);saveflag=1;elseNofind();else if(sel=2)stringinput(findmess,15,請(qǐng)輸入學(xué)生:);p=locate(l,findmess,name);if(p)r=l;while(r-ne*t!=p)r=r-ne*t;r-ne*t=p-ne*t;free(p);printf(n刪除成功!n);saveflag=1;elseNofind();else Wrong();getch();void Qur(Link l)int selec

20、t;char searchinput20;Node *p;system(cls);if(!l-ne*t)printf(n暫無(wú)學(xué)生記錄!n);return;printf(n=1通過(guò)*查找 =2通過(guò)查找n);printf(請(qǐng)選擇12:);scanf(%d,&select);if(select=1)stringinput(searchinput,10,請(qǐng)輸入要查找的*:);p=locate(l,searchinput,num);if(p)printheader();printdata(p);elseNofind();else if(select=2)stringinput(searchinput,1

21、5,請(qǐng)輸入學(xué)生:);p=locate(l,searchinput,name);if(p)printheader();printdata(p);elseNofind();elseWrong();system(PAUSE);void Modify(Link l)Node *p;char findmess20;if(!l-ne*t)system(cls);printf(n沒(méi)有該學(xué)生記錄!n);getch();return;system(cls);printf(修改學(xué)生記錄);Disp(l);stringinput(findmess,10,請(qǐng)輸入*:);p=locate(l,findmess,num)

22、;if(p)printf(*:%s,n,p-data.num);printf(:%s,);stringinput(,15,輸入新的:);printf(c語(yǔ)言:%d,p-data.cgrade);p-data.cgrade=numberinput(c語(yǔ)言0100:);printf(數(shù)學(xué):%d,p-data.mgrade);p-data.mgrade=numberinput(數(shù)學(xué)0100:); printf(英語(yǔ):%d,p-data.egrade); p-data.egrade=numberinput(英語(yǔ)0100:);p-data.total=p-da

23、ta.egrade+p-data.cgrade+p-data.mgrade;p-data.ave=(float)(p-data.total)/3;printf(n=修改成功!);saveflag=1;elseNofind();getch();void Sort(Link l)Link ll;Node *p,*rr,*s;int i=0;system(cls);if(l-ne*t=NULL)printf(n暫無(wú)學(xué)生記錄!n);return;ll=(Node*)malloc(sizeof(Node);/用于創(chuàng)立新的節(jié)點(diǎn)ll-ne*t=NULL;printf(當(dāng)前狀態(tài):n);Disp(l);syst

24、em(PAUSE);p=l-ne*t;while(p)s=(Node*)malloc(sizeof(Node);s-data=p-data;s-ne*t=NULL;rr=ll;while(rr-ne*t!=NULL &rr-ne*t-data.total=p-data.total)rr=rr-ne*t;if(rr-ne*t=NULL)rr-ne*t=s;elses-ne*t=rr-ne*t;rr-ne*t=s;p=p-ne*t;l-ne*t=ll-ne*t;p=l-ne*t;while(p!=NULL)i+;p=p-ne*t;printf(n*n);Disp(l);saveflag=1;pri

25、ntf(n *排序完成* n);system(PAUSE);void Save(Link l) /printf(保存模塊n);/system(PAUSE);FILE *fp;Node *p;int count=0;fp=fopen(student.t*t,wb);p=l-ne*t;while(p)if(fwrite(p,sizeof(Node),1,fp)=1)p=p-ne*t; count+;elsebreak;if(count0)printf(nnnnn 保存完畢,當(dāng)前共有%d名學(xué)生記錄n,count);saveflag=0;elseprintf(空文件,保存失敗!n);fclose(fp

26、);/關(guān)閉文件getch();int login() FILE *fp1,*fp2;int state;char str120,str220,str_z20,str_m7;if(fp1=fopen(admin.t*t,rb)=NULL)printf(本系統(tǒng)無(wú)管理員,請(qǐng)創(chuàng)立!nn請(qǐng)輸入管理員賬號(hào):);scanf(%s,str_z);printf(請(qǐng)?jiān)O(shè)置一個(gè)六位數(shù)密碼:);fp2=fopen(admin.t*t,wb);fprintf(fp2,%s%c,str_z,n); fprintf(fp2,%s%c,str_m, );fclose(fp2);fp1=fopen(admin.t*t,rb);f

27、scanf(fp1,%s,str1);fscanf(fp1,%s,str2);fclose(fp1);while(1)printf(請(qǐng)選擇你的登錄方式:nn); printf(1.管理員模式 0.來(lái)賓模式n);printf(請(qǐng)選擇:(01);scanf(%d,&state);if(state=0)return 0; else if(state=1) printf(請(qǐng)輸入賬號(hào):);scanf(%s,str_z);if (strcmp(str1,str_z)=0&strcmp(str2,str_m)=0)return 1; else printf(賬號(hào)或密碼錯(cuò)誤!an); system(PAUSE

28、); system(cls); else printf(輸入不合法!an);e*it(0); void Modify_admin() FILE *fp; char str_z20,str_m7=; fp=fopen(admin.t*t,wb); printf(請(qǐng)輸入管理員賬號(hào):); scanf(%s,str_z,n); printf(請(qǐng)輸入密碼:); fprintf(fp,%s%c,str_z,n); fprintf(fp,%s%c,str_m, ); fclose(fp); printf(管理員信息更新完畢! an);getch(); int main() Link L; FILE *fp;

29、 int select,State=0; char ch,admin20,admin_p20; int count=0; Node *p,*r; system(color 0A); L=(Node*)malloc(sizeof(Node); L-ne*t=NULL; r=L; fp=fopen(student.t*t,ab+); Loop: State=login(); while(!feof(fp) p=(Node*)malloc(sizeof(Node); if(fread(p,sizeof(Node),1,fp)=1) p-ne*t=NULL; r-ne*t=p; r=p; count+

30、; fclose(fp); if(State=1) while(1) system(cls); printf(n 管理員模式nn); menu(); p=r; scanf(%d,&select); if(select=0) if(saveflag=1) getchar(); printf(n記錄已修改,是否保存當(dāng)時(shí)記錄?(y/n):); scanf(%c,&ch);if(ch=y|ch=Y)Save(L); printf(您的使用!n); break; switch(select) case 1:Add(L);break;/增加模塊 case 2:Del(L);break;/刪除記錄 case 3:Qur(L);break;/查詢模塊 case 4:Modify(L);break;/修改模塊 case 5:Sort(L);break;/排序模塊 case 6:Save(L);break;/保存成績(jī) case 7:Disp(L);system(PAUSE);break;/顯示成績(jī) case 8:system(cls);goto Loop; case 9:Mo

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論