版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 《C++課程設(shè)計》</b></p><p> 課程設(shè)計題目:學(xué)生成績管理系統(tǒng)</p><p> 目 錄</p><p><b> 1、系統(tǒng)總體框架</b></p><p><b> 2、功能分析</b></p>
2、<p><b> 3、模塊設(shè)計與分析</b></p><p><b> 4、類的設(shè)計與分析</b></p><p><b> 5、特色算法分析</b></p><p><b> 6、功能測試</b></p><p> 7、存在的不足與對
3、策</p><p><b> 8、程序源代碼</b></p><p><b> 9、使用說明</b></p><p><b> 系統(tǒng)總體框架</b></p><p><b> 圖1 </b></p><p><b>
4、; 2、功能分析</b></p><p> “學(xué)生成績管理系統(tǒng)”包括九個模塊:輸入學(xué)生資料,輸出學(xué)生資料,學(xué)生姓名按順序排列,添加學(xué)生資料,按姓名查找,刪除該學(xué)生資料,查找并顯示學(xué)生資料,按姓名查找,修改該學(xué)生資料,從文件中讀入數(shù)據(jù),儲存學(xué)生資料并退出系統(tǒng)。這九個模塊既相互聯(lián)系又相互獨(dú)立。</p><p> 本系統(tǒng)根據(jù)學(xué)生成績管理的需要,而建立一個“學(xué)生成績管理系統(tǒng)”,以
5、方便對成績的各項(xiàng)管理操作。本系統(tǒng)能對成績進(jìn)行輸入和輸出;能按姓名對學(xué)生進(jìn)行排序,并顯示學(xué)生資料、成績等,不過得以系統(tǒng)輸入學(xué)生資料、成績?yōu)榍疤?;能添加學(xué)生成績資料;能根據(jù)學(xué)生的姓名來查詢該學(xué)生的成績資料,并修改或是刪除該學(xué)生信息;能夠從文件中讀取學(xué)生信息,并且添加到系統(tǒng)中;能把對系統(tǒng)所進(jìn)行的操作進(jìn)行保存,以及時更新系統(tǒng)中的數(shù)據(jù)。</p><p><b> 3、模塊設(shè)計與分析</b></
6、p><p> (1)輸入學(xué)生資料模塊:</p><p> 主要功能用來對學(xué)生的成績進(jìn)行收集和輸入。在學(xué)生信息保存在系統(tǒng)中的前提下,成績錄入需要輸入學(xué)生資料,比如班級,學(xué)號,姓名。在準(zhǔn)確輸入學(xué)生資料后,就可以對該學(xué)生的各科成績進(jìn)行錄入。該學(xué)生各科成績輸入成功后,系統(tǒng)會提示是否繼續(xù)進(jìn)行操作,如果想繼續(xù)輸入學(xué)生成績就輸入y,不想再輸入學(xué)生成績的話就輸入n,再輸入n之后,系統(tǒng)返回到主菜單。 &l
7、t;/p><p> (2)輸出學(xué)生資料模塊:</p><p> 主要功能用來對學(xué)生的成績進(jìn)行輸出。在系統(tǒng)已經(jīng)錄入了學(xué)生資料成績的前提下,使用該功能可以顯示所有學(xué)生的信息,資料等等。具體包括學(xué)生的班級,學(xué)號,姓名和各科成績。在查看學(xué)生的資料,成績各方面的信息后,按任意鍵就可以返回到主菜單?! ?lt;/p><p> (3) 按學(xué)生姓名進(jìn)行排列模塊</p>
8、<p> 主要功能是用來對學(xué)生的資料按姓名進(jìn)行排序。在系統(tǒng)保存學(xué)生資料,成績的前提下,使用此功能可以對學(xué)生的資料按姓名進(jìn)行排序,這樣就方便查找姓氏相同或是相近的同學(xué)的資料。</p><p> (4) 添加學(xué)生資料模塊</p><p> 主要功能是用來添加學(xué)生資料,成績。如果系統(tǒng)有保存學(xué)生資料的情況下,想錄入學(xué)生成績的話,就不用添加學(xué)生資料這模塊。如果系統(tǒng)沒有保存該學(xué)生信息的
9、話,就要使用此模塊,在成功添加學(xué)生資料后,就可以對該學(xué)生進(jìn)行其他的操作。</p><p> ?。?)按姓名查找,刪除該學(xué)生資料模塊</p><p> 主要功能是用來刪除學(xué)生資料。在系統(tǒng)保存學(xué)生資料的前提下,想刪除某學(xué)生的資料,可以輸入學(xué)生姓名,系統(tǒng)查找該學(xué)生資料后,就可以刪除了。由于學(xué)生輟學(xué),畢業(yè)等原因,及時對系統(tǒng)進(jìn)行更新,刪除一些沒用的信息,可以使系統(tǒng)更加優(yōu)化</p>&
10、lt;p> ?。?)查找并顯示學(xué)生資料模塊</p><p> 主要功能是用來查找學(xué)生資料。在系統(tǒng)保存了某學(xué)生資料的前提下,想要查找該學(xué)生資料,可以輸入該學(xué)生姓名,這樣系統(tǒng)就會顯示該學(xué)生資料和各科成績等信息</p><p> ?。?)按姓名查找,修改學(xué)生資料模塊</p><p> 主要功能是用來修改學(xué)生資料。在系統(tǒng)保存了某學(xué)生資料的前提下,想要查找該學(xué)生資料
11、,可以輸入該學(xué)生姓名,系統(tǒng)就會顯示該學(xué)生資料和各科成績等信息,這樣就可以修改該學(xué)生的資料,成績等信息。</p><p> ?。?)從文件中讀入數(shù)據(jù)模塊</p><p> 主要功能是用來從文件中讀入學(xué)生數(shù)據(jù)。由于一些資料可以用Word文檔或Excel表格輸入,故在此模塊中增加了導(dǎo)入數(shù)據(jù)的功能。這樣就方便很多,不用把學(xué)生資料一個一個添加,節(jié)省了很多時間精力。</p><p
12、> (9)儲存學(xué)生資料并退出系統(tǒng)模塊</p><p> 主要功能是用來儲存學(xué)生資料。在對系統(tǒng)進(jìn)行一系列操作,比如添加、刪除、修改學(xué)生資料后,對系統(tǒng)的最新操作進(jìn)行保存,及時更新系統(tǒng),方便下一次的操作。</p><p><b> 4、類的設(shè)計與分析</b></p><p> Student類類圖</p><p>
13、; typedef class</p><p><b> {</b></p><p><b> public:</b></p><p> char num[10];</p><p> char cla[10];</p><p> char name[20];<
14、;/p><p> char byyl[10];</p><p> char jsjzc[20];</p><p> char sjk[10];</p><p> char jsjyy[20];</p><p> char jsdl[20];</p><p><b> }Stud
15、ent;</b></p><p> 表1 Student類說明表</p><p><b> 5、特色算法分析</b></p><p> 功能:定義菜單函數(shù),通過輸出函數(shù)顯示系統(tǒng)功能。利用switch語句實(shí)現(xiàn)多分支選擇結(jié)構(gòu)。</p><p> 算法思路:switch語句的執(zhí)行流程是:首先計算switc
16、h后面圓括號中表達(dá)式的值,然后用此值依次與各個case的常量表達(dá)式比較,若圓括號中表達(dá)式的值與某個case后面的常量表達(dá)式的值相等,就執(zhí)行此case后面的語句,執(zhí)行后遇break語句就退出switch語句。</p><p><b> 代碼:</b></p><p> void main() //主函數(shù)調(diào)用。</p><p>
17、<b> {</b></p><p><b> int n=0;</b></p><p><b> for(;;)</b></p><p><b> {</b></p><p> switch(menu())</p><p&g
18、t;<b> {</b></p><p><b> case 1:</b></p><p> cout<<setw(15)<<" "<<"輸入學(xué)生資料"<<endl;</p><p> n=Input(stu,n);</p
19、><p><b> break;</b></p><p><b> case 2:</b></p><p> cout<<setw(15)<<" "<<"輸出所有學(xué)生資料"<<endl;</p><p> D
20、isplay(stu,n); </p><p><b> break;</b></p><p><b> case 3:</b></p><p> cout<<setw(15)<<" "<<"按姓名排序"<<endl;</p
21、><p> Sort(stu,n);</p><p> cout<<setw(15)<<" ";</p><p> system("pause");</p><p><b> break;</b></p><p><b>
22、; case 4:</b></p><p> cout<<setw(15)<<" "<<"插入學(xué)生資料"<<endl;</p><p> n=Insert(stu,n);</p><p> cout<<setw(15)<<"
23、";</p><p> system("pause");</p><p><b> break;</b></p><p><b> case 5:</b></p><p> cout<<setw(15)<<" "<
24、;<"刪除學(xué)生資料"<<endl;</p><p> cout<<setw(15)<<" "<<"輸入他(她)的姓名:";</p><p> n=Delete(stu,n);</p><p> cout<<setw(15)<<
25、;" ";</p><p> system("pause");</p><p><b> break;</b></p><p><b> case 6:</b></p><p> cout<<setw(15)<<" &
26、quot;<<"查找學(xué)生"<<endl;</p><p> Query(stu,n);</p><p> cout<<setw(15)<<" ";</p><p> system("pause"); </p><p><b&
27、gt; break;</b></p><p><b> case 7:</b></p><p> cout<<setw(15)<<" "<<"修改學(xué)生資料"<<endl;</p><p> cout<<setw(15)<
28、<" "<<"輸入你要修改的學(xué)生的姓名:";</p><p> n=Xiugai(stu,n);</p><p> system("pause");</p><p><b> break;</b></p><p><b> c
29、ase 8:</b></p><p> cout<<setw(15)<<" "<<"從文件中讀入數(shù)據(jù)"<<endl;</p><p> n=AddfromText(stu,n);</p><p><b> break;</b></p&
30、gt;<p><b> case 0:</b></p><p> cout<<setw(15)<<" "<<"將所有資料寫入文件"<<endl;</p><p> WritetoText(stu,n);</p><p> cout<
31、;<setw(15)<<" ";</p><p> system("pause");</p><p><b> break;</b></p><p><b> }</b></p><p><b> }</b>&l
32、t;/p><p><b> }</b></p><p><b> 6、功能測試</b></p><p> 圖1 學(xué)生成績管理系統(tǒng)主菜單頁面</p><p> 圖二 為輸入學(xué)生資料模塊</p><p> 圖三 為輸出學(xué)生資料模塊</p><p>
33、 圖四 按學(xué)生姓名進(jìn)行排列模塊</p><p> 圖五 為添加學(xué)生資料模塊</p><p> 圖六 為按姓名查找,刪除該學(xué)生資料模塊</p><p> 圖七 為查找并顯示學(xué)生資料模塊</p><p> 圖八 為按姓名查找,修改學(xué)生資料模塊</p><p> 圖九 為從文件中讀入數(shù)據(jù)模塊</p>
34、<p> 圖十 為儲存學(xué)生資料并退出系統(tǒng)模塊</p><p> 7、存在的不足與對策</p><p> 本學(xué)生成績管理系統(tǒng)由九個模塊組成,每個模塊相互聯(lián)系又相互獨(dú)立。這個學(xué)生成績管理系統(tǒng)存在著很多不足之處,由于自己本身編程能力的問題,這個系統(tǒng)可以實(shí)現(xiàn)的功能非常有限。只能實(shí)現(xiàn)學(xué)生管理系統(tǒng)最基本的功能,可以進(jìn)行簡單的輸入、輸出學(xué)生資料,查詢和修改學(xué)生信息,能直接從文件中讀入數(shù)據(jù)
35、,能對系統(tǒng)所作的修改、操作進(jìn)行保存等。而且在每個模塊也有不足的地方,比如在輸入學(xué)生資料時,對每個信息項(xiàng)沒有嚴(yán)格的規(guī)定,可以輸入任何的字符。同時有些模塊還不能實(shí)現(xiàn)本應(yīng)該有的功能,這有待以后努力,爭能夠?qū)崿F(xiàn)該有的功能。</p><p> 在21世紀(jì)的科技時代,科學(xué)技術(shù)突飛猛進(jìn),計算機(jī)已經(jīng)不僅是在科技上應(yīng)用,而且在生活中也是同樣得到了廣泛在應(yīng)用。如今,不管是小學(xué)、初中、高中、甚至是很多大學(xué)生的學(xué)生成績管理基本上是靠人
36、工進(jìn)行管理,但隨著時間的變化,學(xué)校規(guī)模的擴(kuò)大,有關(guān)學(xué)生成績管理工作和所涉及到的數(shù)據(jù)量越來越大越來越多,大多數(shù)學(xué)校不得不靠增加人力、物力、財力來進(jìn)行學(xué)生成績管理。但是人工管理成績檔案具有效率低、查找麻煩、可靠性不高、保密性低等因素。因此開發(fā)出一個不僅僅是適用于大中專院校以及其它高校通用的學(xué)生成績管理系統(tǒng)是必要的。 開發(fā)一個學(xué)生成績管理系統(tǒng),采用計算機(jī)對學(xué)生成績進(jìn)行管理,進(jìn)一步提高了辦學(xué)效益和現(xiàn)代化水平。為廣大教師和學(xué)生提高工作效率
37、,實(shí)現(xiàn)學(xué)生成績信息管理工作流程的系統(tǒng)化、規(guī)范化和自動化?,F(xiàn)在我國的大中專院校的學(xué)生成績檔案管理水平普遍都不是很高,有的還停留在全用紙介質(zhì)基礎(chǔ)上,這種管理方式已不能適應(yīng)時代的發(fā)展,社會的需求,因?yàn)樗速M(fèi)了大量的人力物力,也存在著許多不足的因素。在今天信息時代這種傳統(tǒng)的管理方法必然會被計算機(jī)為基礎(chǔ)的信息管理系統(tǒng)所代替。一個高效的學(xué)生成績管理系統(tǒng)可以存儲歷屆的學(xué)生成績檔案,不需要大量</p><p><b>
38、 8、程序源代碼</b></p><p> #include<iostream></p><p> #include<stdio.h></p><p> #include<ctype.h></p><p> #include<stdlib.h></p><
39、;p> #include<string.h></p><p> #include<iostream></p><p> #include<iomanip></p><p> using namespace std;</p><p> typedef class</p><
40、p><b> {</b></p><p><b> public:</b></p><p> char num[10];</p><p> char cla[10];</p><p> char name[20];</p><p> char byyl[10
41、];</p><p> char jsjzc[20];</p><p> char sjk[10];</p><p> char jsjyy[20];</p><p> char jsdl[20];</p><p><b> }Student;</b></p><p&
42、gt; Student stu[80];</p><p> int menu()</p><p><b> {</b></p><p><b> char c;</b></p><p> for(;c<'0'||c>'8';)</p>
43、<p><b> {</b></p><p> system("cls");</p><p> cout<<" 歡迎使用本學(xué)生成績管理系統(tǒng)?。?quot;<<endl;</p><p> cout<<&qu
44、ot;編程人員:劉迪兆";</p><p> cout<<endl; </p><p> cout<<"****************************** 學(xué)生成績管理系統(tǒng) ****************************** "<<endl;</p><p> cout&
45、lt;<setw(32)<<" "<<"1.輸入學(xué)生資料"<<endl;</p><p> cout<<setw(32)<<" "<<"2.輸出學(xué)生資料"<<endl;</p><p> cout<<set
46、w(32)<<" "<<"3.按學(xué)生姓名進(jìn)行排列"<<endl;</p><p> cout<<setw(32)<<" "<<"4.添加學(xué)生資料"<<endl;</p><p> cout<<setw(32)&l
47、t;<" "<<"5.按姓名查找,刪除該學(xué)生資料"<<endl;</p><p> cout<<setw(32)<<" "<<"6.查找并顯示學(xué)生資料"<<endl;</p><p> cout<<setw(32)&l
48、t;<" "<<"7.按姓名查找,修改該學(xué)生資料"<<endl;</p><p> cout<<setw(32)<<" "<<"8.從文件中讀入數(shù)據(jù)"<<endl;</p><p> cout<<setw(32)<
49、;<" "<<"0.儲存學(xué)生資料并退出系統(tǒng)"<<endl;</p><p> cout<<setfill('=')<<setw(48)<<"="<<endl;</p><p> cout<<setw(15)<<
50、" ";</p><p> cout<<"請選擇(0-8):";</p><p> c=getchar();</p><p><b> }</b></p><p> return(c-'0');</p><p><b
51、> }</b></p><p> int Input(Student stud[],int n) //輸入數(shù)據(jù)。</p><p><b> {</b></p><p><b> int i=0;</b></p><p> char sign,x[10];<
52、/p><p> for(;sign != 'n' && sign != 'N';)</p><p><b> {</b></p><p> cout<<setw(15)<<" "<<"班級:";</p>&
53、lt;p> cin>>stud[n+i].cla;</p><p> cout<<setw(15)<<" "<<"學(xué)號:";</p><p> cin>>stud[n+i].num;</p><p> cout<<setw(15)<&l
54、t;" "<<"姓名:";</p><p> cin>>stud[n+i].name;</p><p> cout<<setw(15)<<" "<<"數(shù)據(jù)結(jié)構(gòu):";</p><p> cin>>stud[n+i
55、].byyl;</p><p> cout<<setw(15)<<" "<<"離散數(shù)學(xué):";</p><p> cin>>stud[n+i].jsjzc;</p><p> cout<<setw(15)<<" "<<&
56、quot;大學(xué)物理:";</p><p> cin>>stud[n+i].sjk;</p><p> cout<<setw(15)<<" "<<"大學(xué)英語:";</p><p> cin>>stud[n+i].jsjyy;</p><
57、;p> cout<<setw(15)<<" "<<"模擬電路:";</p><p> cin>>stud[n+i].jsdl;</p><p><b> gets(x);</b></p><p> cout<<setw(10)<
58、;<" ";</p><p> cout<<"還有要輸入的信息嗎?(y/n)";</p><p> cin>>&sign;</p><p><b> i++;</b></p><p><b> }</b></
59、p><p> return(n+i); </p><p><b> }</b></p><p> void Display(Student stud[], int n) //輸出數(shù)據(jù)。</p><p><b> {</b></p><p><b> i
60、nt i;</b></p><p> cout<<setw(15)<<" "<<setfill('-')<<setw(65)<<"-"<<endl;</p><p> cout<<setw(15)<<" "
61、;<<"班級 學(xué)號 姓名 數(shù)據(jù)結(jié)構(gòu) 離散數(shù)學(xué) 大學(xué)物理 大學(xué)英語 模擬電路"<<endl;</p><p> cout<<setw(15)<<" ";</p><p> cout<<setfill('-')<<setw(65)<<"-&q
62、uot;<<endl;</p><p> for(i=1;i<n+1;i++)</p><p><b> {</b></p><p> printf("\t\t%-9s%-9s%-9s%-9s%-9s%-9s%-9s\n",stud[i-1].cla,stud[i-1].num,stud[i-1].n
63、ame,stud[i-1].byyl,stud[i-1].jsjzc,stud[i-1].sjk,stud[i-1].jsjyy);</p><p> if(i>1 && i%10==0)</p><p><b> {</b></p><p> cout<<setw(15)<<" &
64、quot;<<setfill('-')<<setw(35)<<"-"<<endl;</p><p> cout<<setw(15)<<" ";</p><p> system("pause");</p><p>
65、cout<<setw(15)<<" "<<setfill('-')<<setw(35)<<"-"<<endl;</p><p><b> }</b></p><p><b> }</b></p><
66、;p> cout<<setw(15)<<" ";</p><p> system("pause");</p><p><b> }</b></p><p> void Sort(Student stud[],int n) //按名字排序。</p&g
67、t;<p><b> {</b></p><p><b> int i,j;</b></p><p> char t[20];</p><p> for(i=0;i<n-1;i++)</p><p> for(j=0;j<n-1-i;j++)</p>
68、<p> if(strcmp(stud[j].num,stud[j+1].num)>0)</p><p><b> {</b></p><p> strcpy(t,stud[j+1].cla);</p><p> strcpy(stud[j+1].cla,stud[j].cla);</p><p&g
69、t; strcpy(stud[j].cla,t);</p><p> strcpy(t,stud[j+1].num); </p><p> strcpy(stud[j+1].num,stud[j].num); </p><p> strcpy(stud[j].num,t); </p><p> strcpy(t,stud[j+1].
70、name); </p><p> strcpy(stud[j+1].name,stud[j].name); </p><p> strcpy(stud[j].name,t); </p><p> strcpy(t,stud[j+1].byyl); </p><p> strcpy(stud[j+1].name,stud[j].byyl
71、); </p><p> strcpy(stud[j].byyl,t); </p><p> strcpy(t,stud[j+1].jsjzc); </p><p> strcpy(stud[j+1].name,stud[j].jsjzc); </p><p> strcpy(stud[j].jsjzc,t); </p>
72、<p> strcpy(t,stud[j+1].sjk); </p><p> strcpy(stud[j+1].name,stud[j].sjk); </p><p> strcpy(stud[j].sjk,t); </p><p> strcpy(t,stud[j+1].jsjyy); </p><p> strcp
73、y(stud[j+1].name,stud[j].jsjyy); </p><p> strcpy(stud[j].jsjyy,t); </p><p> strcpy(t,stud[j+1].jsdl); </p><p> strcpy(stud[j+1].name,stud[j].jsdl); </p><p> strcpy(
74、stud[j].jsdl,t); </p><p><b> }</b></p><p> cout<<setw(15)<<" "<<"排序成功!"<<endl;</p><p><b> }</b></p><
75、;p> int Insert(Student stud[],int n) //插入一條學(xué)生信息。</p><p><b> {</b></p><p> char x[10];</p><p> cout<<setw(15)<<" "<<"班級:&qu
76、ot;;</p><p> cin>>stud[n].cla;</p><p> cout<<setw(15)<<" "<<"學(xué)號:";</p><p> cin>>stud[n].num;</p><p> cout<<s
77、etw(15)<<" "<<"姓名:";</p><p> cin>>stud[n].name;</p><p> cout<<setw(15)<<" "<<"數(shù)據(jù)結(jié)構(gòu):";</p><p> cin>&
78、gt;stud[n].byyl;</p><p> cout<<setw(15)<<" "<<"離散數(shù)學(xué):";</p><p> cin>>stud[n].jsjzc;</p><p> cout<<setw(15)<<" "&l
79、t;<"大學(xué)物理:";</p><p> cin>>stud[n].sjk;</p><p> cout<<setw(15)<<" "<<"大學(xué)英語:";</p><p> cin>>stud[n].jsjyy;</p>
80、<p> cout<<setw(15)<<" "<<"模擬電路:";</p><p> cin>>stud[n].jsdl;</p><p><b> gets(x);</b></p><p><b> n++;</b>
81、;</p><p> cout<<setw(15)<<" "<<"插入成功!"<<endl;</p><p> return(n);</p><p><b> }</b></p><p> int Delete(Student
82、 stud[],int n) //按名字查找信息,刪除信息。</p><p><b> {</b></p><p> char s[20];</p><p> int i=0,j;</p><p><b> cin>>s;</b></p><p
83、> while(strcmp(stud[i].name,s)!=0&&i<n) i++; /*查找判斷*/ </p><p><b> if(i==n) </b></p><p><b> {</b></p><p> printf("\t\t\t沒有發(fā)現(xiàn)該學(xué)生資料!\n&qu
84、ot;); /*返回失敗信息*/ </p><p> return(n); </p><p><b> } </b></p><p> for(j=i;j<n-1;j++) /*刪除操作*/ </p><p><b> { </b></p><p> strc
85、py(stud[j].num,stud[j+1].num); </p><p> strcpy(stud[j].name,stud[j+1].name); </p><p> strcpy(stud[j].cla,stud[j+1].cla);</p><p> strcpy(stud[j].byyl,stud[j+1].byyl);</p>&
86、lt;p> strcpy(stud[j].jsjzc,stud[j+1].jsjzc);</p><p> strcpy(stud[j].sjk,stud[j+1].sjk); </p><p> strcpy(stud[j].jsjyy,stud[j+1].jsjyy);</p><p> strcpy(stud[j].jsdl,stud[j+1].
87、jsdl);</p><p><b> } </b></p><p> cout<<setw(15)<<" "<<"當(dāng)前信息已刪除成功!"<<endl; /*返回成功信息*/ </p><p> return(n-1); </p><
88、;p><b> }</b></p><p> void Query(Student stud[],int n) //按名字查找信息</p><p><b> {</b></p><p> char s[20];</p><p><b> int i=0;</
89、b></p><p> cout<<setw(15)<<" "<<"輸入他(她)的姓名:";</p><p><b> cin>>s;</b></p><p> while(strcmp(stud[i].name,s)!=0&&i
90、<n) </p><p> i++; /*查找判斷*/ </p><p><b> if(i==n) </b></p><p><b> {</b></p><p> printf("\t\t\t沒有發(fā)現(xiàn)該學(xué)生資料!\n"); /*輸入失敗信息*/ </p&g
91、t;<p><b> return; </b></p><p><b> } </b></p><p> cout<<setw(15)<<" "<<"學(xué)號:"<<stud[i].num<<endl;</p><
92、;p> cout<<setw(15)<<" "<<"數(shù)據(jù)結(jié)構(gòu):"<<stud[i].byyl<<endl;</p><p> cout<<setw(15)<<" "<<"離散數(shù)學(xué):"<<stud[i].jsjzc<
93、;<endl;</p><p> cout<<setw(15)<<" "<<"大學(xué)物理:"<<stud[i].sjk<<endl;</p><p> cout<<setw(15)<<" "<<"大學(xué)英語:"
94、<<stud[i].jsjyy<<endl;</p><p> cout<<setw(15)<<" "<<"模擬電路:"<<stud[i].jsdl<<endl;</p><p><b> }</b></p><p>
95、 int Xiugai(Student stud[],int n) //修改信息。</p><p><b> {</b></p><p> n=Delete(stud,n);</p><p> cout<<setw(15)<<" "<<"輸入你要修改的學(xué)生資
96、料"<<endl;</p><p> n=Insert(stud,n);</p><p> cout<<setw(15)<<" "<<"修改完成"<<endl;</p><p> return(n);</p><p><b
97、> }</b></p><p> int AddfromText(Student stud[], int n) //從文件中讀入數(shù)據(jù)。</p><p><b> {</b></p><p> int i=0,num;</p><p><b> FILE *fp;</b
98、></p><p> char filename[20];</p><p> cout<<setw(15)<<" "<<"輸入文件名:";</p><p> cin>>filename;</p><p> if((fp=fopen(filen
99、ame,"rb"))==NULL)</p><p><b> {</b></p><p> cout<<setw(15)<<" "<<"無法打開文件"<<endl;</p><p> cout<<setw(15)<
100、<" ";</p><p> system("pause");</p><p> return(n);</p><p><b> }</b></p><p> fscanf(fp,"%d",&num);</p><p&g
101、t; for(;i<num;)</p><p><b> {</b></p><p> fscanf(fp,"%s%s%s%s%s%s%s",stud[n+i].cla,stud[n+i].num,stud[n+i].name,stud[n+i].byyl,stud[n+i].jsjzc,stud[n+i].sjk,stud[n+i].
102、jsjyy,stud[n+i].jsdl); </p><p><b> i++;</b></p><p><b> }</b></p><p><b> n+=num;</b></p><p> fclose(fp);</p><p> co
103、ut<<setw(15)<<" "<<"讀入成功!"<<endl;</p><p> cout<<setw(15)<<" ";</p><p> system("pause");</p><p> return
104、(n);</p><p><b> }</b></p><p> void WritetoText(Student stud[],int n) //將所有記錄寫入文件。</p><p><b> {</b></p><p><b> int i=0;</b>
105、;</p><p><b> FILE *fp;</b></p><p> char filename[20];</p><p> cout<<setw(15)<<" "<<"將資料輸入文件"<<endl;</p><p>
106、cout<<setw(15)<<" "<<"輸入文件名:";</p><p> cin>>filename;</p><p> if((fp=fopen(filename,"w"))==NULL)</p><p><b> {</b>
107、;</p><p> cout<<setw(15)<<" "<<"無法打開文件"<<endl;</p><p> system("pause");</p><p><b> return;</b></p><p&
108、gt;<b> }</b></p><p> fprintf(fp,"%d\n",n); </p><p> for(;i<n;)</p><p><b> {</b></p><p> fprintf(fp,"%-6s%-5s%-5s%-5s%-5s
109、%-5s%-5s\n",stud[i].cla,stud[i].num,stud[i].name,stud[i].byyl,stud[i].jsjzc,stud[i].sjk,stud[i].jsjyy); </p><p><b> i++;</b></p><p><b> }</b></p><p>
110、 fclose(fp);</p><p> cout<<setw(15)<<" "<<"輸入成功!"<<endl;</p><p><b> int b;</b></p><p> cout<<setw(15)<<"
111、"<<"請確定是否退出系統(tǒng):"<<endl;</p><p> cout<<setw(15)<<" "<<"0.退出系統(tǒng)"<<endl;</p><p> cout<<setw(15)<<" "<
112、<"1.返回"<<endl;</p><p><b> cin>>b;</b></p><p><b> if(b==0)</b></p><p><b> {</b></p><p> cout<<setw
113、(15)<<" "<<"謝謝使用!"<<endl;</p><p> cout<<setw(15)<<" ";</p><p> system("pause");</p><p><b> exit(0);<
114、;/b></p><p><b> }</b></p><p><b> }</b></p><p> void main() //主函數(shù)調(diào)用。</p><p><b> {</b></p><p><b> i
115、nt n=0;</b></p><p><b> for(;;)</b></p><p><b> {</b></p><p> switch(menu())</p><p><b> {</b></p><p><b>
116、 case 1:</b></p><p> cout<<setw(15)<<" "<<"輸入學(xué)生資料"<<endl;</p><p> n=Input(stu,n);</p><p><b> break;</b></p>&
117、lt;p><b> case 2:</b></p><p> cout<<setw(15)<<" "<<"輸出所有學(xué)生資料"<<endl;</p><p> Display(stu,n); </p><p><b> break;&l
118、t;/b></p><p><b> case 3:</b></p><p> cout<<setw(15)<<" "<<"按姓名排序"<<endl;</p><p> Sort(stu,n);</p><p> cou
119、t<<setw(15)<<" ";</p><p> system("pause");</p><p><b> break;</b></p><p><b> case 4:</b></p><p> cout<<
120、setw(15)<<" "<<"插入學(xué)生資料"<<endl;</p><p> n=Insert(stu,n);</p><p> cout<<setw(15)<<" ";</p><p> system("pause")
121、;</p><p><b> break;</b></p><p><b> case 5:</b></p><p> cout<<setw(15)<<" "<<"刪除學(xué)生資料"<<endl;</p><p&g
122、t; cout<<setw(15)<<" "<<"輸入他(她)的姓名:";</p><p> n=Delete(stu,n);</p><p> cout<<setw(15)<<" ";</p><p> system("paus
123、e");</p><p><b> break;</b></p><p><b> case 6:</b></p><p> cout<<setw(15)<<" "<<"查找學(xué)生"<<endl;</p>&
124、lt;p> Query(stu,n);</p><p> cout<<setw(15)<<" ";</p><p> system("pause"); </p><p><b> break;</b></p><p><b> ca
125、se 7:</b></p><p> cout<<setw(15)<<" "<<"修改學(xué)生資料"<<endl;</p><p> cout<<setw(15)<<" "<<"輸入你要修改的學(xué)生的姓名:";<
126、/p><p> n=Xiugai(stu,n);</p><p> system("pause");</p><p><b> break;</b></p><p><b> case 8:</b></p><p> cout<<setw
127、(15)<<" "<<"從文件中讀入數(shù)據(jù)"<<endl;</p><p> n=AddfromText(stu,n);</p><p><b> break;</b></p><p><b> case 0:</b></p>&
128、lt;p> cout<<setw(15)<<" "<<"將所有資料寫入文件"<<endl;</p><p> WritetoText(stu,n);</p><p> cout<<setw(15)<<" ";</p><p>
129、; system("pause");</p><p><b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p>&l
130、t;p><b> 9、使用手冊</b></p><p> ?。?)用戶進(jìn)入系統(tǒng)后,就會看到學(xué)生管理系統(tǒng)的主菜單頁面。系統(tǒng)總共有九個模塊,分別由0到8表示,在主菜單頁面只能輸入數(shù)字0到8,輸入其他字符無效,如果用戶輸入無效字符,系統(tǒng)仍停留在主菜單頁面。</p><p> (2)進(jìn)入到主菜單頁面后,用戶可以根據(jù)自己的需求選擇不同的選項(xiàng),選擇后系統(tǒng)就會進(jìn)入子系統(tǒng)頁
溫馨提示
- 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文畢業(yè)論文
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文
- 學(xué)生成績管理系統(tǒng)-畢業(yè)論文
- 學(xué)生成績管理系統(tǒng)——畢業(yè)論文
- 學(xué)生成績管理系統(tǒng)——畢業(yè)論文
- 畢業(yè)論文——學(xué)生成績管理系統(tǒng)
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文
- 畢業(yè)論文-學(xué)生成績管理系統(tǒng)
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文
- 畢業(yè)論文-學(xué)生成績管理系統(tǒng)
- 學(xué)生成績管理系統(tǒng) 畢業(yè)論文
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文7
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文 (3)
- 畢業(yè)論文學(xué)生成績管理系統(tǒng)
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文 (2)
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文 (2)
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文9
- 學(xué)生成績管理系統(tǒng)畢業(yè)論文1
評論
0/150
提交評論