




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上信息技術(shù)工程學(xué)院C語言課程設(shè)計(jì)報(bào)告 題目:學(xué)生成績管理系統(tǒng)(student achievement management system)目錄 一 設(shè)計(jì)目的通過本課程設(shè)計(jì)鞏固C語言程序設(shè)計(jì)課程的教學(xué)成果,深入理解結(jié)構(gòu)體、指針、鏈表、動(dòng)態(tài)分配內(nèi)存和文件操作的等C程序設(shè)計(jì)中的中高級(jí)技術(shù),通過課程設(shè)計(jì)的綜合訓(xùn)練,培養(yǎng)學(xué)生實(shí)際分析問題、編程和動(dòng)手能力、提高學(xué)生利用C語言進(jìn)行程序設(shè)計(jì)的能力,初步培養(yǎng)良好的編程習(xí)慣和編程風(fēng)格,初步學(xué)習(xí)程序的文檔的撰寫方法。二 課程設(shè)計(jì)的內(nèi)容通過C語言程序系統(tǒng),設(shè)計(jì)一個(gè)可以對(duì)學(xué)生的成績信息進(jìn)行管理的程序,其中學(xué)生的信息可以包括:學(xué)號(hào)、各科目的成績的平
2、均分排序等,其功能可以包括學(xué)生成績的輸入、輸出、查詢、排序、刪除、統(tǒng)計(jì)、退出等。三 課程設(shè)計(jì)的要求與數(shù)據(jù)1、用C語言實(shí)現(xiàn)系統(tǒng);2、對(duì)學(xué)生信息(包括學(xué)號(hào)、姓名、語文、數(shù)學(xué)、英語、平均分)進(jìn)行管理,包括學(xué)生成績的信息輸入、輸出、查詢、刪除、排序、統(tǒng)計(jì)、退出、顯示,以及整個(gè)程序的切換登錄模式和修改管理員的信息.3、學(xué)生信息包括: (1)、每一條記錄包括一個(gè)學(xué)生的學(xué)號(hào)、姓名、3門課成績(2)、成績信息錄入功能:(成績信息用文件保存,可以一次完成若干條記錄的輸入。)(3)、成績信息顯示瀏覽功能:完成全部學(xué)生記錄的顯示。(4)、查詢功能:完成按姓名查找學(xué)生記錄,并顯示。(5)、成績信息的刪除:按學(xué)號(hào)進(jìn)行刪
3、除某學(xué)生的成績.(6)、排序功能:按學(xué)生平均成績進(jìn)行排序。(7)、應(yīng)提供一個(gè)界面來調(diào)用各個(gè)功能,調(diào)用界面和各個(gè)功能的操作界面應(yīng)盡可能清晰美觀!四 課程設(shè)計(jì)應(yīng)完成的工作(1)編寫算法;(2)算法測試,并有具體的測試結(jié)果和結(jié)果分析;(3)撰寫課程設(shè)計(jì)報(bào)告。內(nèi)容包括:1) 封面扉頁2) 設(shè)計(jì)任務(wù)書3) 目錄4) 總體設(shè)計(jì)方案(包括流程圖)5) 使用說明及運(yùn)行實(shí)例(包括界面)6) 成員設(shè)計(jì)內(nèi)容簡介7) 項(xiàng)目源程序代碼(注意注釋的使用)8) 指導(dǎo)教師評(píng)語五 總體設(shè)計(jì)(包含幾大功能模塊)1、成績錄入功能2、成績輸出功能3、成績查詢功能4、刪除模塊 5、排序功能 6、統(tǒng)計(jì)功能 7、退出系統(tǒng)六 詳細(xì)設(shè)計(jì)6.1
4、各個(gè)模塊的功能和實(shí)現(xiàn)(1)整個(gè)成績管理系統(tǒng)設(shè)計(jì)分為9個(gè)模塊:1.輸入學(xué)生成績2.刪除學(xué)生成績3.查詢學(xué)生成績4.修改學(xué)生成績5.排序?qū)W生成績6.保存記錄7.顯示所有8.退出系統(tǒng)9.修改管理員信息(2)(主要函數(shù)的功能) 1.主函數(shù)main():定義學(xué)生結(jié)構(gòu)體數(shù)組,調(diào)用錄入,統(tǒng)計(jì)等函數(shù)對(duì)成績表進(jìn)行處理。 2.輸入數(shù)據(jù)函數(shù)input():輸入學(xué)號(hào)、成績。 3排序函數(shù)sort():對(duì)總成績或者平均成績,進(jìn)行排序,按從高到低或者從低到高。 4.顯示數(shù)據(jù)函數(shù)display():顯示各個(gè)學(xué)生的總成績 5新增數(shù)據(jù)函數(shù)insert():增加學(xué)生學(xué)生記錄。 6.刪除數(shù)據(jù)函數(shù)del():由于各種原因,刪除某些同學(xué)
5、的成績、學(xué)號(hào)等。7.平均值函數(shù)average():求各個(gè)同學(xué)總成績的平均值。8.查詢數(shù)據(jù)函數(shù)qur():查詢學(xué)生的信息。 9.保存數(shù)據(jù)函數(shù)save():再一次打開界面是,仍有上次所找的訊息。10.退出系統(tǒng)函數(shù)exit():當(dāng)要退出整個(gè)系統(tǒng)時(shí)。6.2 流程圖(管理員模式流程圖)輸出菜單輸入 根據(jù)菜單輸入n的值選擇程序結(jié)束開始保存查找退出刪除統(tǒng)計(jì)插入排序輸出開始(來賓模式流程圖) 輸出菜單根據(jù)菜單,選擇程序退出程序切換登錄排序成績顯示成績查詢成績 結(jié)束七 調(diào)試分析(各模塊測試結(jié)果)7.1源代碼#include<stdio.h>#include<string.h>#inclu
6、de<time.h>#include<stdlib.h>#include<conio.h>#define HEADER2 " 學(xué)號(hào) 姓名 數(shù)學(xué) 英語 C語言 總分 平均分n"#define FORMAT " %s %s %d %d %d %d %.2fn"#define DATA p->data.num,p->,p->data.mgrade,p->data.egrade,p->data.cgrade,p->data.total,p->data.aveint s
7、aveflag=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(" 學(xué)生成績管理系統(tǒng) n"); printf("n");
8、 printf(" *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"); pr
9、intf(" * *n"); printf(" *n"); printf(" * 8 切換登錄模式 9 修改管理員信息 *n"); printf(" *n"); printf("n 請你選擇操作命令前的的數(shù)字(09):");int menu2() /int select; time_t now; now=time(NULL); system("cls"); /清屏 printf("n 學(xué)生模式nnn"); printf(" 學(xué)生成績管理系統(tǒng) n&
10、quot;); 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&quo
11、t;); printf("n 請你選擇操作命令前的數(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沒有該學(xué)生!n");Node* locate(Link l,char findmess,char nameornum) N
12、ode *r; if(strcmp(nameornum,"num")=0) r=l->next; while(r) if(strcmp(r->data.num,findmess)=0) return r; r=r->next; else if(strcmp(nameornum,"name")=0) r=l->next; while(r) if(strcmp(r->,findmess)=0) return r; r=r->next; return 0;void stringinput(char*t,in
13、t 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(t>100|t<0) printf("n 分?jǐn)?shù)必須在0100之間!n&q
14、uot;); while(t>100|t<0); return t;void Disp(Link l) Node *p; system("cls"); p=l->next; if(!p) printf("n目前無學(xué)生成績記錄!n"); getch(); return; printf("nn"); printheader(); while(p) printdata(p); p=p->next;/移至下一個(gè)結(jié)點(diǎn) void Add(Link l)/printf("增加學(xué)生記錄模塊n");/syst
15、em("PAUSE"); Node *p,*r,*s;char ch,flag=0,num10;r=l;system("cls");Disp(l);/先打印已有的學(xué)生信息while(r->next!=NULL)r=r->next;/將只指針移至鏈表末尾,準(zhǔn)備添加記錄while(1)/一次可輸入條記錄,直至輸入的學(xué)號(hào)我0的記錄節(jié)點(diǎn)添加操作s=l->next;while(1)stringinput(num,10,"學(xué)號(hào)(按0退出):");flag=0;if(strcmp(num,"0")=0)retu
16、rn;s=l->next;while(s)/查詢學(xué)號(hào)是否存在,若存在則要求重新輸入if(strcmp(s->data.num,num)=0)flag=1; break;s=s->next;if(flag=1)/提示用戶是否重新輸入getchar();printf("=>學(xué)號(hào)%s已存在,是否重新輸入?(y/n)a:",num);scanf("%c",&ch);if(ch='y'|ch='Y')continue;elsereturn ;elsebreak;p=(Node *)malloc(siz
17、eof(Node);strcpy(p->data.num,num);/將字符串mun拷貝到p->data.num中stringinput(p->,15,"name:");p->data.cgrade=numberinput("c語言0-100:"); p->data.mgrade=numberinput("數(shù)學(xué)0-100:"); p->data.egrade=numberinput("英語0-100:");p->data.total=p->data.
18、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("刪除學(xué)生記錄模塊n");/system("PAUSE"); int sel;Node *p,*r;char findmess20;if(!l->next)system(&quo
19、t;cls");printf("n=>暫無學(xué)生記錄!n");getch();return;system("cls");Disp(l);printf("n 1通過學(xué)號(hào)刪除 2通過姓名刪除n");printf(" 請選擇1,2");scanf("%d",&sel);if(sel=1)stringinput(findmess,10,"請輸入學(xué)號(hào):");p=locate(l,findmess,"num");if(p)r=l;while(r-
20、>next!=p)r=r->next;r->next=p->next;free(p);/釋放內(nèi)存空間printf("n刪除成功!n");saveflag=1;elseNofind();else if(sel=2)stringinput(findmess,15,"請輸入學(xué)生姓名:");p=locate(l,findmess,"name");if(p)r=l;while(r->next!=p)r=r->next;r->next=p->next;free(p);printf("n刪除
21、成功!n");saveflag=1;elseNofind();else Wrong();getch();void Qur(Link l)int select;char searchinput20;Node *p;system("cls");if(!l->next)printf("n暫無學(xué)生記錄!n");return;printf("n=>1通過學(xué)號(hào)查找 =>2通過姓名查找n");printf("請選擇12:");scanf("%d",&select);if(s
22、elect=1)stringinput(searchinput,10,"請輸入要查找的學(xué)號(hào):");p=locate(l,searchinput,"num");if(p)printheader();printdata(p);elseNofind();else if(select=2)stringinput(searchinput,15,"請輸入學(xué)生姓名:");p=locate(l,searchinput,"name");if(p)printheader();printdata(p);elseNofind();else
23、Wrong();system("PAUSE");void Modify(Link l)Node *p;char findmess20;if(!l->next)system("cls");printf("n沒有該學(xué)生記錄!n");getch();return;system("cls");printf("修改學(xué)生記錄");Disp(l);stringinput(findmess,10,"請輸入學(xué)號(hào):");p=locate(l,findmess,"num"
24、);if(p)printf("學(xué)號(hào):%s,n",p->data.num);printf("姓名:%s,",p->);stringinput(p->,15,"輸入新的姓名:");printf("c語言:%d,",p->data.cgrade);p->data.cgrade=numberinput("c語言0100:");printf("數(shù)學(xué):%d,",p->data.mgrade);p->data.m
25、grade=numberinput("數(shù)學(xué)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=>修改成功!");saveflag=1;elseNo
26、find();getch();void Sort(Link l)Link ll;Node *p,*rr,*s;int i=0;system("cls");if(l->next=NULL)printf("n暫無學(xué)生記錄!n");return;ll=(Node*)malloc(sizeof(Node);/用于創(chuàng)建新的節(jié)點(diǎn)ll->next=NULL;printf("當(dāng)前狀態(tài):n");Disp(l);system("PAUSE");p=l->next;while(p)s=(Node*)malloc(siz
27、eof(Node);s->data=p->data;s->next=NULL;rr=ll;while(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->
28、next;printf("n*n");Disp(l);saveflag=1;printf("n *排序完成* n");system("PAUSE"); void Save(Link l) /printf("保存模塊n");/system("PAUSE");FILE *fp;Node *p;int count=0;fp=fopen("student.txt","wb");p=l->next;while(p)if(fwrite(p,sizeof(Node
29、),1,fp)=1)p=p->next; count+;elsebreak;if(count>0)printf("nnnnn 保存完畢,當(dāng)前共有%d名學(xué)生記錄n",count);saveflag=0;elseprintf("空文件,保存失敗!n");fclose(fp);/關(guān)閉文件getch();int login() FILE *fp1,*fp2;int state;char str120,str220,str_z20,str_m7;if(fp1=fopen("admin.txt","rb")=NUL
30、L)printf("本系統(tǒng)無管理員,請創(chuàng)建!nn請輸入管理員賬號(hào):");scanf("%s",str_z);printf("請?jiān)O(shè)置一個(gè)六位數(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",&quo
31、t;rb");fscanf(fp1,"%s",str1);fscanf(fp1,"%s",str2);fclose(fp1);while(1)printf("請選擇你的登錄方式:nn"); printf("1.管理員模式 0.來賓模式n");printf("請選擇:(01)");scanf("%d",&state);if(state=0)return 0; else if(state=1) printf("請輸入賬號(hào):");scanf(&
32、quot;%s",str_z); if (strcmp(str1,str_z)=0&&strcmp(str2,str_m)=0)return 1; else printf("賬號(hào)或密碼錯(cuò)誤!an"); system("PAUSE"); system("cls"); else printf("輸入不合法!an");exit(0); void Modify_admin() FILE *fp; char str_z20,str_m7="" fp=fopen("adm
33、in.txt","wb"); printf("請輸入管理員賬號(hào):"); 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;
34、FILE *fp; int select,State=0; char ch,admin20,admin_p20; int count=0; Node *p,*r; system("color 0A"); 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(
35、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",&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;/保存成績 case 7:Disp
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 共享經(jīng)濟(jì)模式下的勞動(dòng)關(guān)系研究-洞察闡釋
- 基于深度學(xué)習(xí)的土地利用覆被遙感分類技術(shù)研究進(jìn)展與展望
- 冬小麥氮素分配與莖稈維管束結(jié)構(gòu)的相互關(guān)系研究
- 利用改進(jìn)YOLOv8算法進(jìn)行蝸桿表面缺陷檢測的研究與實(shí)踐
- 城市經(jīng)濟(jì)現(xiàn)象:微觀視角下的宏觀經(jīng)濟(jì)規(guī)律研究
- 消費(fèi)品市場增長動(dòng)力-洞察闡釋
- 胎兒腦囊腫的護(hù)理查房
- 會(huì)厭膿腫的護(hù)理查房
- 外耳道膿腫護(hù)理課件
- 骨折延遲愈合個(gè)案護(hù)理
- 完整市政工程分部分項(xiàng)劃分
- 《市場調(diào)查》考試題庫及答案(復(fù)習(xí)用)
- 比亞迪宋PLUS EV說明書
- 2020長沙市一中新高一入學(xué)分班考試試卷
- 2022年大連市莊河市社區(qū)工作者招聘考試試題
- 洗浴中心的物業(yè)管理方案
- 人教版七年級(jí)(初一)數(shù)學(xué)上冊全冊標(biāo)準(zhǔn)課講義終稿(教師版)
- 鹽酸安羅替尼三線治療非小細(xì)胞肺癌(NSCLC)的療效和安全性的III期臨床試驗(yàn)
- 蘇教版必修1《離子反應(yīng)》優(yōu)秀課件
- 復(fù)合樹脂粘接修復(fù)術(shù)的基本操作步驟
- 二手車買賣合同電子版下載
評(píng)論
0/150
提交評(píng)論