版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 學(xué)生成績表</b></p><p> 課題設(shè)計內(nèi)容、具備的功能:</p><p><b> [系統(tǒng)功能]</b></p><p> 1)新增學(xué)生數(shù)據(jù)的添加:學(xué)號,姓名,性別,3門課程成績,計算總成績并顯示。</p><p> 2)修改學(xué)生成績數(shù)據(jù):輸入學(xué)號,根據(jù)
2、學(xué)號,修改該生的3項成績數(shù)據(jù)計算總成績并顯示。</p><p> 3)刪除一個學(xué)生:輸入學(xué)號,根據(jù)學(xué)號刪除該生。</p><p> 4)根據(jù)學(xué)號查詢:輸入學(xué)號,查找該生并顯示學(xué)生數(shù)據(jù)。</p><p> 5)顯示全部學(xué)生數(shù)據(jù)。</p><p> 6)根據(jù)學(xué)號從小到大排序?qū)W生數(shù)據(jù)。</p><p> 7)根據(jù)總
3、成績從大到小排序?qū)W生數(shù)據(jù)。</p><p> 8)退出:保存學(xué)生總數(shù)文件及學(xué)生數(shù)據(jù)文件,然后結(jié)束程序運(yùn)行。</p><p><b> [系統(tǒng)設(shè)計要求]</b></p><p> 1)在Visual C++控制臺應(yīng)用程序方式下設(shè)計課題。</p><p> 2)設(shè)計的程序要求規(guī)定的功能。</p><
4、;p> 3)程序應(yīng)具有一定的健壯性。即程序必須具有必要的檢查和出錯處理,如在新增學(xué)生數(shù)據(jù)時檢查輸入的學(xué)號是否相同。刪除、查詢學(xué)生時檢查輸入的學(xué)號是否存在等。</p><p> 模塊(函數(shù))的劃分、各模板(函數(shù))的功能:</p><p> int EnterChoice();//輸入選項</p><p> void Init();
5、//數(shù)據(jù)文件初始化</p><p> void Add(); //增加一個學(xué)生</p><p> void Update();//修改學(xué)生成績</p><p> void Delete();//刪除一個學(xué)生</p>
6、<p> void Query();//查詢學(xué)生數(shù)據(jù)</p><p> void Display();//顯示全部學(xué)生</p><p> void Display(Student*); //顯示全部學(xué)生</p><p> void SortNo();//按學(xué)號排序(從
7、小到大)</p><p> void SortScore();//按成績排序(從大到小)</p><p> void SaveTxt();//以二進(jìn)制形式保存數(shù)據(jù)</p><p> int CheckNo(char *);//輸入學(xué)號</p><p> void PrintTitl
8、e();//顯示表頭</p><p> void GetData(Student*);//讀取學(xué)生成績數(shù)據(jù)</p><p> 采用的自定義的數(shù)據(jù)類型:</p><p> 1) 建立student工程</p><p> 2) 在頭文件中,設(shè)計Student結(jié)構(gòu)類型,成員為</p><
9、p> char No[5] 學(xué)號</p><p> char Name[8]姓名</p><p> char Gender[7]性別</p><p> int Score[4]3門課程成績及總成績</p><p> 程序設(shè)計過程、調(diào)試中過程中所用的測試用例、測試方法,程序運(yùn)行的結(jié)果:</p>&l
10、t;p> 程序運(yùn)行的結(jié)果通過截圖來顯現(xiàn)。下面的程序是顯示的九個功能:</p><p> 程序運(yùn)行后的菜單顯示:</p><p><b> 增加學(xué)生信息界面:</b></p><p><b> 修改學(xué)生信息:</b></p><p><b> 刪除學(xué)生信息界面:</b&
11、gt;</p><p><b> 查詢學(xué)生信息:</b></p><p><b> 顯示所有學(xué)生信息:</b></p><p><b> 按學(xué)生學(xué)號排序:</b></p><p><b> 按學(xué)生分?jǐn)?shù)排序:</b></p><p
12、> 結(jié)束操作界面:結(jié)束操作界面:</p><p> 在課程設(shè)計中遇到的問題和解決的方法,還沒有能解決的問題:</p><p> 1)特別注意各種C++代碼的運(yùn)用。</p><p> 2)按照規(guī)范的步驟進(jìn)行,程序調(diào)試好之后,由于實(shí)驗環(huán)境不同,需要重新建立工程及文件,在新建.h文件時,要注意文件名要與.cpp文件中定義的頭文件一致,否則程序因找不到正確的.
13、h文件而無法正常運(yùn)行。</p><p> 3)在程序運(yùn)行出現(xiàn)問題時積極地詢問老師或查詢資料。</p><p> 4)在運(yùn)行中出現(xiàn)一些不細(xì)心導(dǎo)致的小問題,經(jīng)過同學(xué)討論都一一解決。</p><p> 六、 通過課程設(shè)計的體會、收獲:</p><p> 在為期不到兩周的課程設(shè)計中,我體會頗多,學(xué)到很多東西。利用這次課程設(shè)計的機(jī)會,我加
14、強(qiáng)了對C++的認(rèn)識,復(fù)習(xí)了自己以前的知識,自己的邏輯思考能力也提高不少。從而對Microsoft Visual C++ 6.0又有了更深入的認(rèn)識!總之,通過這次課程設(shè)計,我收獲頗豐,相信會為自己以后的學(xué)習(xí)和工作帶來很大的好處。最重要的還是激發(fā)了我編程的興趣和熱情,讓我從一個只懂理論變成了能做一些小型程序,讓我對編程更加熱愛了。整體地評價這次課程設(shè)計,我認(rèn)為收獲很大,正如上面所說的那樣,通過課程設(shè)計,既復(fù)習(xí)了以前的舊知識,又學(xué)到了一些新的
15、知識;設(shè)計增強(qiáng)了我們用所學(xué)知識去解決具體問題的能力,進(jìn)一步培養(yǎng)了我們獨(dú)立思考問題和解決問題的能力。當(dāng)然,老師的悉心指導(dǎo)和同學(xué)的幫助也是不可忽視的,在此感謝本次課程設(shè)計中所有輔導(dǎo)老師對我的關(guān)心和幫助,誠心誠意感謝他們對我的鼓勵與教導(dǎo),是她在我迷茫的時候給了我些許提示,激發(fā)了我編程的靈感;還有,我在此也十分感謝本次課程設(shè)計中同學(xué)們對我的幫助,盡管本次不是團(tuán)隊合作,但是他們也給了我不少的提示和幫助,是他們讓我有信心堅持做下來,在此感謝他們!理
16、論的擁有并不能代表我們的實(shí)力和能力,一</p><p> 七、 源程序代碼:</p><p> ?。?)//結(jié)構(gòu)定義文件</p><p> //Student.h</p><p> #ifndef STUDENT_H</p><p> #define STUDENT_H</p><p&
17、gt; Struct Student</p><p><b> {</b></p><p> Char No[9];</p><p> Char Name[9];</p><p> Char Gender[7];</p><p> Int Score[4];</p>&l
18、t;p><b> };</b></p><p><b> #endif</b></p><p> ?。?)//函數(shù)實(shí)現(xiàn)文件</p><p> // student.cpp</p><p> #include<iostream></p><p> #
19、include<iomanip></p><p> #include<fstream></p><p> #include<cstring></p><p> #include"student.h"</p><p> using namespace std;</p>
20、<p> int EnterChoice();</p><p> void Init();</p><p> void Add();</p><p> void Update();</p><p> void Delete();</p><p> void Query();</p>
21、<p> void SortScore();</p><p> void Display();</p><p> void Display(Student*);</p><p> void SortNo();</p><p> void SaveTxt();</p><p> int Check
22、No(char*);</p><p> void PrintTitle();</p><p> void GetData(Student*);</p><p> extern const int MaxNum=100;</p><p> extern int CurNum;</p><p> extern S
23、tudent student[MaxNum];</p><p><b> //輸入選擇函數(shù)</b></p><p> int EnterChoice()</p><p><b> {</b></p><p> cout<<"\nEnter your Choice\n&q
24、uot;</p><p> <<"1:add student 2:update student\n"</p><p> <<"3:delete student 4:query student\n"</p><p> <<"5:displa
25、y students 6:Sort student by NO\n"</p><p> <<"7:Sort student by score 8:end\n";</p><p> int Choice;</p><p> cin>>Choice;</p><p>
26、 return Choice;</p><p><b> }</b></p><p><b> //初始化函數(shù)</b></p><p> void Init()</p><p><b> {</b></p><p> ifstream inCo
27、unt,inStudent;</p><p> ofstream outCount,outStudent;</p><p> inCount.open("count.txt",ios::in);</p><p> if(!inCount)</p><p><b> {</b></p>
28、;<p> inCount.close();</p><p> outCount.open("count.txt",ios::out);</p><p> outCount<<CurNum;</p><p> outCount.close();</p><p><b> }&l
29、t;/b></p><p><b> else</b></p><p><b> {</b></p><p> inCount>>CurNum;</p><p> inCount.close();</p><p><b> }</b
30、></p><p> if(CurNum)</p><p><b> {</b></p><p> inStudent.open("student.txt",ios::in);</p><p> for(int i=0;i<CurNum;i++)</p><p&
31、gt;<b> {</b></p><p> inStudent>>(student+i)->No;</p><p> inStudent>>(student+i)->Name;</p><p> inStudent>>(student+i)->Gender;</p>
32、<p> inStudent>>(student+i)->Score[0];</p><p> inStudent>>(student+i)->Score[1];</p><p> inStudent>>(student+i)->Score[2];</p><p> inStudent>
33、>(student+i)->Score[3];</p><p><b> }</b></p><p> inStudent.close();</p><p><b> }</b></p><p><b> else</b></p><p&
34、gt;<b> {</b></p><p> outStudent.open("Student.txt",ios::out);</p><p> outStudent.close();</p><p><b> }</b></p><p><b> }<
35、/b></p><p><b> //增加一個學(xué)生</b></p><p> void Add()</p><p><b> {</b></p><p> char no[9];</p><p> cout<<"No=";<
36、;/p><p><b> cin>>no;</b></p><p> int i=CheckNo(no);</p><p><b> if(i>=0)</b></p><p> cout<<"No.repeated,input again"<
37、;<endl;</p><p><b> else</b></p><p><b> {</b></p><p> strcpy(student[CurNum].No,no);</p><p> cout<<"Name=";</p><
38、;p> cin>>(student+CurNum)->Name;</p><p> cout<<"Gender=";</p><p> cin>>(student+CurNum)->Gender;</p><p> GetData(student+CurNum);</p>
39、<p> PrintTitle();</p><p> Display(student+CurNum);</p><p><b> CurNum++;</b></p><p><b> }</b></p><p><b> }</b></p>
40、<p> 按學(xué)生號從小到大冒泡排序,并顯示</p><p> void SortNo()</p><p><b> {</b></p><p> Student temp;</p><p><b> int flag;</b></p><p> for
41、(int i=0;i<CurNum-1;i++)</p><p><b> {</b></p><p><b> flag=1;</b></p><p> for(int j=0;j<CurNum-1-i;j++)</p><p><b> {</b><
42、;/p><p> if(strcmp(student[j+1].No,student[j].No)<0)</p><p><b> {</b></p><p><b> flag=0;</b></p><p> temp=student[j+1];student[j+1]=student[
43、j];student[j]=temp;</p><p><b> }</b></p><p><b> }</b></p><p> if(flag)break;</p><p><b> }</b></p><p> Display();&l
44、t;/p><p><b> }</b></p><p><b> //顯示表頭</b></p><p> void PrintTitle()</p><p><b> {</b></p><p> cout<<setiosflags(i
45、os_base::left);</p><p> cout<<setw(6)<<"No"<<setw(8)<<"Name"<<setw(10)<<"Gender"<<setw(10)<<"Score1"<<setw(10)&l
46、t;<"Score2"<<setw(10)<<"Score3"<<setw(10)<<"SCore"<<endl;</p><p><b> }</b></p><p><b> //顯示學(xué)生情況</b></p&
47、gt;<p> void Display()</p><p><b> {</b></p><p> if(CurNum)</p><p><b> {</b></p><p> PrintTitle();</p><p> for(int i=0;
48、i<CurNum;i++)</p><p> Display(student+i);</p><p><b> }</b></p><p><b> else</b></p><p> cout<<"The list empty!"<<end
49、l;</p><p><b> }</b></p><p> //顯示一個學(xué)生情況</p><p> void Display(Student* stu)</p><p><b> {</b></p><p> cout<<setiosflags(ios
50、_base::left);</p><p> cout<<setw(6)<<stu->No;</p><p> cout<<setw(8)<<stu->Name;</p><p> cout<<setw(6)<<stu->Gender;</p><p&
51、gt; cout<<resetiosflags(ios_base::left);</p><p> cout<<setw(10)<<stu->Score[0];</p><p> cout<<setw(10)<<stu->Score[1];</p><p> cout<<se
52、tw(10)<<stu->Score[2];</p><p> cout<<setw(10)<<stu->Score[3]<<endl;</p><p><b> }</b></p><p> //保存學(xué)生數(shù)據(jù)到文本文件</p><p> void Sa
53、ve()</p><p><b> {</b></p><p> ofstream outCount,outStudent;</p><p> outCount.open("count.txt",ios::out);</p><p> outCount<<CurNum;</p
54、><p> outCount.close();</p><p> outStudent.open ("student.txt",ios::out);</p><p> for(int i=0;i<CurNum;i++)</p><p><b> {</b></p><p&
55、gt; outStudent<<(student+i)->No<<" ";</p><p> outStudent<<(student+i)->Name<<" ";</p><p> outStudent<<(student+i)->Gender<<&qu
56、ot; ";</p><p> outStudent<<(student+i)->Score[0]<<" ";</p><p> outStudent<<(student+i)->Score[1]<<" ";</p><p> outStudent&l
57、t;<(student+i)->Score[2]<<" ";</p><p> outStudent<<(student+i)->Score[3]<<" ";</p><p> outStudent<<endl;</p><p><b> }&l
58、t;/b></p><p> outStudent.close();</p><p><b> }</b></p><p> //檢查學(xué)號是否存在,找到返回所在數(shù)組下標(biāo),找不到返回-1</p><p> int CheckNo(char* no)</p><p><b>
59、 {</b></p><p> for(int i=0;i<CurNum;i++)</p><p> if(strcmp(student[i].No,no)==0)</p><p><b> return i;</b></p><p> return -1;</p><p&g
60、t;<b> }</b></p><p><b> 讀入學(xué)生3項成績</b></p><p> void GetData(Student* stu)</p><p><b> {</b></p><p> for(int i=0;i<3;i++)</p&g
61、t;<p><b> {</b></p><p> cout<<"Score"<<i<<"= ";</p><p> cin>>stu->Score[i];</p><p><b> }</b></p&
62、gt;<p> stu->Score[3]=stu->Score[0]+stu->Score[1]+stu->Score[2];</p><p><b> }</b></p><p> 按學(xué)生總成績從大到小排序</p><p> void SortScore()</p><p&g
63、t;<b> {</b></p><p> Student temp;</p><p> int i,j,max;</p><p> for(i=0;i<CurNum-1;i++)</p><p><b> { max=i;</b></p><p> fo
64、r(j=i;j<CurNum;j++)</p><p> if(student[max].Score[3]<student[j].Score[3])</p><p><b> max=j;</b></p><p> if(max!=i){</p><p> temp=student[max];<
65、/p><p> student[max]=student[i];</p><p> student[i]=temp;</p><p><b> }</b></p><p><b> }</b></p><p> Display();</p><p&g
66、t;<b> }</b></p><p> //根據(jù)輸入的學(xué)生號,刪除該學(xué)生</p><p> void Update()</p><p><b> {</b></p><p> char no[9];char c;</p><p> cout<<&q
67、uot;input no:";</p><p><b> cin>>no;</b></p><p> int i=CheckNo(no);</p><p><b> if(i<0)</b></p><p> cout<<"The number
68、 dose not exist!\n";</p><p><b> else{</b></p><p> cout<<"Update Score[0]?(y/n)\n";</p><p><b> cin>>c;</b></p><p>
69、 if(c=='y'||c=='Y')</p><p><b> {</b></p><p> cout<<"Input Score[0]:";</p><p> cin>>student[i].Score[0];</p><p><
70、b> }</b></p><p> cout<<"Update Score[1]?(y/n)\n";</p><p><b> cin>>c;</b></p><p> if(c=='y'||c=='Y')</p><p&g
71、t;<b> {</b></p><p> cout<<"Input Score[1]:";</p><p> cin>>student[i].Score[1];</p><p><b> }</b></p><p> cout<<&
72、quot;Update Score[2]?(y/n)\n";</p><p><b> cin>>c;</b></p><p> if(c=='y'||c=='Y')</p><p><b> {</b></p><p> cout<
73、;<"Input Score[2]:";</p><p> cin>>student[i].Score[2];</p><p><b> }</b></p><p> student->Score[3]=student->Score[0]+student->Score[1]+stud
74、ent->Score[2];</p><p><b> }</b></p><p> PrintTitle();</p><p> Display(student+i);</p><p><b> }</b></p><p> //根據(jù)輸入的號,查找該生并顯示
75、</p><p> void Query()</p><p><b> {</b></p><p> char no[9];</p><p> cout<<"input no:";</p><p><b> cin>>no;</
76、b></p><p> int i=CheckNo(no);</p><p><b> if(i<0)</b></p><p> cout<<"The nunber dose not exist! \n";</p><p><b> else</b>
77、;</p><p><b> {</b></p><p> PrintTitle();</p><p> Display(student+i);</p><p><b> }</b></p><p><b> }</b></p>
78、<p><b> //主函數(shù)文件</b></p><p> //main.cpp</p><p> #include <iostream></p><p> #include <fstream></p><p> #include <iomanip></p&g
79、t;<p> #include <string></p><p> #include "Student.h"</p><p> using namespace std;</p><p> int EnterChoice();</p><p> void Init();
80、</p><p> void Add();</p><p> void Display();</p><p> void DisplayOne(Student*);</p><p> void SortNo();</p><
81、;p> void Save (); </p><p> int CheckNo(char *);</p><p> void PrintTitle();</p><p> void GetData(Student*);</p><p> void Update();
82、</p><p> void Delete();</p><p> void Query();</p><p> void SortScore();</p><p><b> enum </b></p><p> Choices
83、{ADD=1,UPDATE,DELETE,QUERY,DISPLAY,SORTNO,SORTSCORE,END};</p><p> const int MaxNum=100;</p><p> int CurNum;</p><p> Student student[MaxNum];</p><p>
84、 void main()</p><p><b> {</b></p><p><b> Init();</b></p><p> int choice;</p><p> while((choice=EnterChoice())!=END)</p><p><
85、b> {</b></p><p> switch(choice){</p><p><b> case ADD:</b></p><p><b> Add();</b></p><p><b> break;</b></p><p
86、> case UPDATE:</p><p><b> Update();</b></p><p><b> break;</b></p><p> case DELETE:</p><p><b> Delete();</b></p><p
87、><b> break;</b></p><p> case QUERY:</p><p><b> Query();</b></p><p><b> break;</b></p><p> case DISPLAY:</p><p>
88、 Display();</p><p><b> break;</b></p><p> case SORTNO:</p><p><b> SortNo();</b></p><p><b> break;</b></p><p> cas
89、e SORTSCORE:</p><p> SortScore();</p><p><b> break;</b></p><p><b> default:</b></p><p> cerr<<"Incorrect choice\n";}</p&g
溫馨提示
- 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- c++課程設(shè)計--學(xué)生成績管理
- c++課程設(shè)計--學(xué)生成績管理
- c++課程設(shè)計----學(xué)生成績管理系統(tǒng)
- c++課程設(shè)計----學(xué)生成績管理系統(tǒng)
- 學(xué)生成績管理系統(tǒng)c++課程設(shè)計
- c++課程設(shè)計-學(xué)生成績管理系統(tǒng)
- c++課程設(shè)計---學(xué)生成績管理系統(tǒng)
- c++課程設(shè)計---學(xué)生成績管理系統(tǒng)
- c++課程設(shè)計——學(xué)生成績管理系統(tǒng)
- c++課程設(shè)計--學(xué)生成績管理系統(tǒng)
- c++學(xué)生成績管理系統(tǒng)課程設(shè)計
- c++課程設(shè)計--學(xué)生成績管理系統(tǒng)
- c++語言課程設(shè)計 ----學(xué)生成績統(tǒng)計
- c++課程設(shè)計--- 學(xué)生成績管理系統(tǒng)設(shè)計
- c++學(xué)生成績管理系統(tǒng)課程設(shè)計報告
- c++學(xué)生成績管理系統(tǒng)課程設(shè)計報告
- c++學(xué)生成績管理系統(tǒng)課程設(shè)計報告
- c++課程設(shè)計報告--學(xué)生成績管理系統(tǒng)
- c&c++課程設(shè)計-學(xué)生成績管理系統(tǒng)
- c++課程設(shè)計--學(xué)生成績排名系統(tǒng)
評論
0/150
提交評論