




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、信息技術工程學院C語言課程設計報告 題目:學生成績管理系統(tǒng)(student achievement management system)目錄 一 設計目的3二 課程設計的內容3三 課程設計的要求與數(shù)據(jù)4四 課程設計應完成的工作4五 總體設計(包含幾大功能模塊)5六 詳細設計66.1各個模塊的功能和實現(xiàn)66.2 流程圖7(管理員模式流程圖)7(來賓模式流程圖)88七 調試分析(各模塊測試結果)97.1源代碼97.2 各模塊測試結果24八 總結29九 參考資料30一 設計目的通過本課程設計鞏固C語言程序設計課程的教學成果,深入理解結構體、指針、鏈表、動態(tài)分配內存和文件操作的等C程序設計中的中高級技
2、術,通過課程設計的綜合訓練,培養(yǎng)學生實際分析問題、編程和動手能力、提高學生利用C語言進行程序設計的能力,初步培養(yǎng)良好的編程習慣和編程風格,初步學習程序的文檔的撰寫方法。二 課程設計的內容通過C語言程序系統(tǒng),設計一個可以對學生的成績信息進行管理的程序,其中學生的信息可以包括:學號、各科目的成績的平均分排序等,其功能可以包括學生成績的輸入、輸出、查詢、排序、刪除、統(tǒng)計、退出等。三 課程設計的要求與數(shù)據(jù)1、用C語言實現(xiàn)系統(tǒng);2、對學生信息(包括學號、姓名、語文、數(shù)學、英語、平均分)進行管理,包括學生成績的信息輸入、輸出、查詢、刪除、排序、統(tǒng)計、退出、顯示,以及整個程序的切換登錄模式和修改管理員的信息
3、.3、學生信息包括: (1)、每一條記錄包括一個學生的學號、姓名、3門課成績(2)、成績信息錄入功能:(成績信息用文件保存,可以一次完成若干條記錄的輸入。)(3)、成績信息顯示瀏覽功能:完成全部學生記錄的顯示。(4)、查詢功能:完成按姓名查找學生記錄,并顯示。(5)、成績信息的刪除:按學號進行刪除某學生的成績.(6)、排序功能:按學生平均成績進行排序。(7)、應提供一個界面來調用各個功能,調用界面和各個功能的操作界面應盡可能清晰美觀!四 課程設計應完成的工作(1)編寫算法;(2)算法測試,并有具體的測試結果和結果分析;(3)撰寫課程設計報告。內容包括:1) 封面扉頁2) 設計任務書3) 目錄4
4、) 總體設計方案(包括流程圖)5) 使用說明及運行實例(包括界面)6) 成員設計內容簡介7) 項目源程序代碼(注意注釋的使用)8) 指導教師評語五 總體設計(包含幾大功能模塊)1、成績錄入功能2、成績輸出功能3、成績查詢功能4、刪除模塊 5、排序功能 6、統(tǒng)計功能 7、退出系統(tǒng)六 詳細設計6.1各個模塊的功能和實現(xiàn)(1)整個成績管理系統(tǒng)設計分為9個模塊:1.輸入學生成績2.刪除學生成績3.查詢學生成績4.修改學生成績5.排序學生成績6.保存記錄7.顯示所有8.退出系統(tǒng)9.修改管理員信息(2)(主要函數(shù)的功能) 1.主函數(shù)main():定義學生結構體數(shù)組,調用錄入,統(tǒng)計等函數(shù)對成績表進行處理。
5、2.輸入數(shù)據(jù)函數(shù)input():輸入學號、成績。 3排序函數(shù)sort():對總成績或者平均成績,進行排序,按從高到低或者從低到高。 4.顯示數(shù)據(jù)函數(shù)display():顯示各個學生的總成績 5新增數(shù)據(jù)函數(shù)insert():增加學生學生記錄。 6.刪除數(shù)據(jù)函數(shù)del():由于各種原因,刪除某些同學的成績、學號等。7.平均值函數(shù)average():求各個同學總成績的平均值。8.查詢數(shù)據(jù)函數(shù)qur():查詢學生的信息。 9.保存數(shù)據(jù)函數(shù)save():再一次打開界面是,仍有上次所找的訊息。10.退出系統(tǒng)函數(shù)exit():當要退出整個系統(tǒng)時。6.2 流程圖(管理員模式流程圖)輸出菜單輸入 根據(jù)菜單輸入n
6、的值選擇程序結束開始保存查找退出刪除統(tǒng)計插入排序輸出開始(來賓模式流程圖) 輸出菜單根據(jù)菜單,選擇程序退出程序切換登錄排序成績顯示成績查詢成績 結束七 調試分析(各模塊測試結果)7.1源代碼#include#include#include#include#include#define HEADER2 學號 姓名 數(shù)學 英語 C語言 總分 平均分n#define FORMAT %s %s %d %d %d %d %.2fn#define DATA p-data.num,,p-data.mgrade,p-data.egrade,p-data.cgrade,p-data.tot
7、al,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 student data; struct node *next;Node,*Link;void menu() time_t now; now=time(NULL); printf( 學生成績管理系統(tǒng) n); printf(n); print
8、f( *n); printf( * *n); printf( * 1 輸入成績 2 刪除成績 *n); printf( * *n); printf( * 3 查詢成績 4 修改成績 *n); printf( * *n); printf( * 5 排序成績 6 保存記錄 *n); printf( * *n); printf( * 7 顯示所有 0 退出系統(tǒng) *n); printf( * *n); printf( *n); printf( * 8 切換登錄模式 9 修改管理員信息 *n); printf( *n); printf(n 請你選擇操作命令前的的數(shù)字(09):);int menu2()
9、/int select; time_t now; now=time(NULL); system(cls); /清屏 printf(n 學生模式nnn); printf( 學生成績管理系統(tǒng) n); printf(n); printf( *n); printf( * *n); printf( * 1 查詢成績 2 排序成績 *n); printf( * *n); printf( * 3 顯示所有 0 退出系統(tǒng) *n); printf( * *n); printf( *n); printf( * 4 切換登錄模式 *n); printf( *n); printf(n 請你選擇操作命令前的數(shù)字(04)
10、:); return 0;void printheader() printf(HEADER2);void printdata(Node *pp) Node *p;p=pp; printf(FORMAT,DATA);void Wrong()printf(nnnn*錯誤:輸入不合法!*an);getch();void Nofind()printf(n沒有該學生!n);Node* locate(Link l,char findmess,char nameornum) Node *r; if(strcmp(nameornum,num)=0) r=l-next; while(r) if(strcmp(r
11、-data.num,findmess)=0) return r; r=r-next; else if(strcmp(nameornum,name)=0) r=l-next; while(r) if(strcmp(,findmess)=0) return r; r=r-next; return 0;void stringinput(char*t,int lens,char*notice) char n225; do printf(notice); scanf(%s,n); if(strlen(n)lens) printf(n超出寬度!n);while(strlen(n)le
12、ns);strcpy(t,n); int numberinput(char *notice)int t=0; do printf(notice); scanf(%d,&t); if(t100|t100|tnext; if(!p) printf(n目前無學生成績記錄!n); getch(); return; printf(nn); printheader(); while(p) printdata(p); p=p-next;/移至下一個結點 void Add(Link l)/printf(增加學生記錄模塊n);/system(PAUSE); Node *p,*r,*s;char ch,flag=
13、0,num10;r=l;system(cls);Disp(l);/先打印已有的學生信息while(r-next!=NULL)r=r-next;/將只指針移至鏈表末尾,準備添加記錄while(1)/一次可輸入條記錄,直至輸入的學號我0的記錄節(jié)點添加操作s=l-next;while(1)stringinput(num,10,學號(按0退出):);flag=0;if(strcmp(num,0)=0)return;s=l-next;while(s)/查詢學號是否存在,若存在則要求重新輸入if(strcmp(s-data.num,num)=0)flag=1; break;s=s-next;if(flag
14、=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.num中stringinput(,15,name:);p-data.cgrade=numberinput(c語言0-100:); p-data.mgrade=numberinput(數(shù)學0-100:)
15、; p-data.egrade=numberinput(英語0-100:);p-data.total=p-data.cgrade+p-data.mgrade+p-data.egrade;p-data.ave=(float)(p-data.total/3);p-next=NULL;while(r-next!=NULL)r=r-next;r-next=p;saveflag=1;void Del(Link l) / printf(刪除學生記錄模塊n);/system(PAUSE); int sel;Node *p,*r;char findmess20;if(!l-next)system(cls);p
16、rintf(n=暫無學生記錄!n);getch();return;system(cls);Disp(l);printf(n 1通過學號刪除 2通過姓名刪除n);printf( 請選擇1,2);scanf(%d,&sel);if(sel=1)stringinput(findmess,10,請輸入學號:);p=locate(l,findmess,num);if(p)r=l;while(r-next!=p)r=r-next;r-next=p-next;free(p);/釋放內存空間printf(n刪除成功!n);saveflag=1;elseNofind();else if(sel=2)string
17、input(findmess,15,請輸入學生姓名:);p=locate(l,findmess,name);if(p)r=l;while(r-next!=p)r=r-next;r-next=p-next;free(p);printf(n刪除成功!n);saveflag=1;elseNofind();else Wrong();getch();void Qur(Link l)int select;char searchinput20;Node *p;system(cls);if(!l-next)printf(n暫無學生記錄!n);return;printf(n=1通過學號查找 =2通過姓名查找n)
18、;printf(請選擇12:);scanf(%d,&select);if(select=1)stringinput(searchinput,10,請輸入要查找的學號:);p=locate(l,searchinput,num);if(p)printheader();printdata(p);elseNofind();else if(select=2)stringinput(searchinput,15,請輸入學生姓名:);p=locate(l,searchinput,name);if(p)printheader();printdata(p);elseNofind();elseWrong();sy
19、stem(PAUSE);void Modify(Link l)Node *p;char findmess20;if(!l-next)system(cls);printf(n沒有該學生記錄!n);getch();return;system(cls);printf(修改學生記錄);Disp(l);stringinput(findmess,10,請輸入學號:);p=locate(l,findmess,num);if(p)printf(學號:%s,n,p-data.num);printf(姓名:%s,);stringinput(,15,輸入新的姓名:);pr
20、intf(c語言:%d,p-data.cgrade);p-data.cgrade=numberinput(c語言0100:);printf(數(shù)學:%d,p-data.mgrade);p-data.mgrade=numberinput(數(shù)學0100:); printf(英語:%d,p-data.egrade); p-data.egrade=numberinput(英語0100:);p-data.total=p-data.egrade+p-data.cgrade+p-data.mgrade;p-data.ave=(float)(p-data.total)/3;printf(n=修改成功!);sav
21、eflag=1;elseNofind();getch();void Sort(Link l)Link ll;Node *p,*rr,*s;int i=0;system(cls);if(l-next=NULL)printf(n暫無學生記錄!n);return;ll=(Node*)malloc(sizeof(Node);/用于創(chuàng)建新的節(jié)點ll-next=NULL;printf(當前狀態(tài):n);Disp(l);system(PAUSE);p=l-next;while(p)s=(Node*)malloc(sizeof(Node);s-data=p-data;s-next=NULL;rr=ll;whil
22、e(rr-next!=NULL &rr-next-data.total=p-data.total)rr=rr-next;if(rr-next=NULL)rr-next=s;elses-next=rr-next;rr-next=s;p=p-next;l-next=ll-next;p=l-next;while(p!=NULL)i+;p=p-next;printf(n*n);Disp(l);saveflag=1;printf(n *排序完成* n);system(PAUSE); void Save(Link l) /printf(保存模塊n);/system(PAUSE);FILE *fp;Node
23、 *p;int count=0;fp=fopen(student.txt,wb);p=l-next;while(p)if(fwrite(p,sizeof(Node),1,fp)=1)p=p-next; count+;elsebreak;if(count0)printf(nnnnn 保存完畢,當前共有%d名學生記錄n,count);saveflag=0;elseprintf(空文件,保存失敗!n);fclose(fp);/關閉文件getch();int login() FILE *fp1,*fp2;int state;char str120,str220,str_z20,str_m7;if(fp
24、1=fopen(admin.txt,rb)=NULL)printf(本系統(tǒng)無管理員,請創(chuàng)建!nn請輸入管理員賬號:);scanf(%s,str_z);printf(請設置一個六位數(shù)密碼:); fp2=fopen(admin.txt,wb);fprintf(fp2,%s%c,str_z,n); fprintf(fp2,%s%c,str_m, );fclose(fp2);fp1=fopen(admin.txt,rb);fscanf(fp1,%s,str1);fscanf(fp1,%s,str2);fclose(fp1);while(1)printf(請選擇你的登錄方式:nn); printf(1.
25、管理員模式 0.來賓模式n);printf(請選擇:(01);scanf(%d,&state);if(state=0)return 0; else if(state=1) printf(請輸入賬號:);scanf(%s,str_z); if (strcmp(str1,str_z)=0&strcmp(str2,str_m)=0)return 1; else printf(賬號或密碼錯誤!an); system(PAUSE); system(cls); else printf(輸入不合法!an);exit(0); void Modify_admin() FILE *fp; char str_z20
26、,str_m7=; fp=fopen(admin.txt,wb); printf(請輸入管理員賬號:); scanf(%s,str_z,n); printf(請輸入密碼:); fprintf(fp,%s%c,str_z,n); fprintf(fp,%s%c,str_m, ); fclose(fp); printf(管理員信息更新完畢! an);getch(); int main() Link L; FILE *fp; int select,State=0; char ch,admin20,admin_p20; int count=0; Node *p,*r; system(color 0A)
27、; L=(Node*)malloc(sizeof(Node); L-next=NULL; r=L; fp=fopen(student.txt,ab+); Loop: State=login(); while(!feof(fp) p=(Node*)malloc(sizeof(Node); if(fread(p,sizeof(Node),1,fp)=1) p-next=NULL; r-next=p; r=p; count+; fclose(fp); if(State=1) while(1) system(cls); printf(n 管理員模式nn); menu(); p=r; scanf(%d,
28、&select); if(select=0) if(saveflag=1) getchar(); printf(n記錄已修改,是否保存當時記錄?(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;/保存成績 case 7:Disp(L);system(PAUSE);break;/顯示成績 case 8:system(cls);goto Loop; case 9:Modify_admin();break; default:Wrong();getch();break; elsewhile(1)system(cls);menu
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 【正版授權】 ISO/IEC 14888-4:2024 EN Information security - Digital signatures with appendix - Part 4: Stateful hash-based mechanisms
- 2025年充電樁充電設備生產許可證申請與審批合同
- 2025年度新能源汽車充電樁建設與運營服務合同-@-3
- 2024 年度中國汽車行業(yè)爭議解決報告
- 2025年度小時工維修養(yǎng)護服務合同范本
- 2025年度知識產權保險產品代理與服務合同
- 2025年心電遙測監(jiān)護儀項目合作計劃書
- 英語-黑龍江省大慶市實驗中學2024-2025學年高一上學期階段考試
- 2025年瀝青試驗儀器項目合作計劃書
- 2025年度走讀生戶外活動安全責任承諾協(xié)議范本
- 中建雨季專項施工方案
- 《我國個人所得稅制下稅收征管問題研究》
- 建筑工程三通一平技術方案
- 綠化養(yǎng)護工安全培訓
- 婦產科課件-早產臨床防治指南(2024)解讀
- DB21-T 1720-2017海水源熱泵系統(tǒng)工程技術規(guī)程
- 組長競選課件教學課件
- 《基于UTAUT2模型的虛擬學術社區(qū)用戶持續(xù)使用意愿影響因素研究》
- 2022年公務員多省聯(lián)考《申論》真題(遼寧A卷)及答案解析
- 2024 ESC慢性冠脈綜合征指南解讀(全)
- 消防設施操作員(初級)題庫與參考答案
評論
0/150
提交評論