版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、<p><b> 目錄</b></p><p> 引言------------------------------------------------------------1</p><p> 一、系統(tǒng)概述------------------------------------------------2</p><p> 二
2、、需求分析------------------------------------------------2</p><p> 1、系統(tǒng)需求-------------------------------------------2</p><p> 2、開發(fā)環(huán)境-------------------------------------------4</p><p>
3、; 三、詳細設計------------------------------------------------6</p><p> 四、所遇到的問題和分析解決--------------------------15</p><p> 五、系統(tǒng)特色及關鍵技術--------------------------------16</p><p> 六、結論及心得
4、體會--------------------------------------16</p><p> 七、附錄(源代碼)--------------------------------------17</p><p> 參考文獻-----------------------------------------------------35</p><p><
5、;b> 引言</b></p><p> 通過本課程設計,使自己更加系統(tǒng)地理解和掌握數據結構的基本概念;能自如地根據實際要求,設計相應的數據結構,并運用C或C++語言實現所設計的算法,編寫較大型的程序,分析和解決實際應用問題,進一步加深、鞏固所學專業(yè)課程的基本理論知識,理論聯(lián)系實際,進一步培養(yǎng)自己綜合分析問題和解決問題的能力。掌握C語言或C++語言獨立的編寫、調試應用程序和進行其它相關設計的技
6、能。</p><p> 此項目主要是考察我們對結構體、數組、文件等具體操作,以及對C語言語法的掌握,所以做成此項目要求比較高的設計要求,對整體有很熟悉的概括,同時調試過程也是很重要的,對程序界面的要求也比較高,要設計的合理同時也要美觀一點,能夠人性化的描述清楚你的各個功能,一目了然,對其他用戶使用本程序簡單易懂,這才能成本程序或本系統(tǒng)是成功的。</p><p> 對于學生成績管理系統(tǒng),
7、此項目每年都有學生去做,但是能夠在其他項目中脫穎而出,還要有自己的設計特色,用簡單的語言詳細描述系統(tǒng)的功能,這才是關鍵。</p><p> 這個設計能夠練習我們的理解和運用結構化程序設計的思想和方法,掌握開發(fā)一個小型實用系統(tǒng)的基本方法,學會調試一個比較長的程序的基本方法,同時掌握書寫程序設計開發(fā)文檔的能力。</p><p><b> 1</b></p>
8、<p><b> 系統(tǒng)概述</b></p><p> 1、課程設計應完成的工作</p><p><b> ?。?)編寫算法</b></p><p> (2)算法測試,并有具體的測試結果和結果分析</p><p> (3)撰寫課程報告,內容包括:</p><p
9、><b> ?、俜饷?lt;/b></p><p><b> ②目錄</b></p><p><b> ?、壅n程設計報告正文</b></p><p><b> ?、苁褂谜f明</b></p><p><b> ?、輩⒖嘉墨I</b>&l
10、t;/p><p> 2、總體設計工作(包含幾大功能模塊)</p><p> ?。?)輸入學生信息并保存到文件 </p><p> ?。?)讀取文件并輸出學生信息</p><p> (3)按學號及學期查詢</p><p> ?。?)按姓名及學期查詢</p><p> ?。?)按學號及學期修改信息&
11、lt;/p><p><b> ?。?)插入信息</b></p><p> ?。?)按學號及學期刪除信息</p><p> ?。?)按數據結構降序(冒泡)排序</p><p> ?。?)按總分降序(選擇)排序</p><p> ?。?0)統(tǒng)計各科成績的總分和平均分</p><p>
12、;<b> ?。?1)退出</b></p><p><b> 需求分析</b></p><p><b> 1、系統(tǒng)需求</b></p><p><b> 問題描述:</b></p><p> 該系統(tǒng)實現對若干個大學生的學習成績進行管理。至少包括以下
13、信息:</p><p> 學號、姓名、科目、成績,學期。學期取值范圍可為1-8。</p><p><b> 2</b></p><p><b> ?。?)功能要求:</b></p><p> 1.使用中文菜單,界面設計和用戶輸入輸出要人性化些;</p><p> 2.
14、 將學生信息保存在文本文檔中,具體對學生信息進行插入刪除查詢操作時,將保存在文本文檔中的學生信息提取出來,保存在自己定義的數據結構中,然后再對該數據結構進行操作,所有操作完成,或者在相應的命令后,再將學生信息保存到文本文檔中。</p><p> 3.具有數據輸入功能,輸入的數據能最終保存在文件中;</p><p> 4.具有數據刪除功能,能最終從文件中刪除;</p>&l
15、t;p> 5.排序功能,根據自己設計的數據結構,設計排序算法</p><p> 6.具有多種查詢(如按學號查詢、按姓名查詢、按成績查詢等)及輸出功能;</p><p> 7.其它功能(如各種統(tǒng)計,統(tǒng)計每個學生所有課程的平均分,統(tǒng)計某門課程所有學生的平均分等等)</p><p> 8.學生信息的修改(比如修改學生姓名,修改學生某門課程的成績)</p
16、><p><b> ?。?)說明:</b></p><p> ?、俟δ芨鞣矫嬖酵晟圃胶?lt;/p><p> ②自定義的數據結構可以使用數組,鏈表,樹等,然后根據不 同的數據結構,設計不同的排序,查找算法。其中,排序算法至少有兩種,可以使用多種數據結構來存放數據,然后在其上使用不同的排序算法。</p><p> ?、廴粲?/p>
17、數組,必須動態(tài)分配空間(文本文件中最好有一行表示學生人數)</p><p> ?。?)、輸入輸出的形式</p><p> 本系統(tǒng)是一個學生成績管理系統(tǒng),采用VC++6.0 編譯器作為開 發(fā)環(huán)境,這個環(huán)境是我們在學習C++的平臺。輸入數據類型主要是char、int、float等數據類型,輸入內容包括:學期、學號、姓名、高等數學成績,數據機構成績,組成原理成績,總分,平均分等數據。用戶在輸入
18、學生數據時要保證輸入數據格式的正確性,系統(tǒng)不會自動檢測輸入的數據是否正確,輸出形式與輸入形式類似,根據需要可以選擇顯示輸入的各項內容,還可以選擇顯示計算好平均分后并排序后的記錄,顯示內容包括:學期、學號、姓名、高等數學成績,數據機構成績,組成原理成績,總分,平均分等數據。</p><p><b> 3</b></p><p><b> 開發(fā)環(huán)境</
19、b></p><p> Visual C++不僅僅是是一個C++編譯器,而是一個基于Windows操作系統(tǒng)的可視化集成開發(fā)環(huán)境IDE,這種環(huán)境開發(fā)出來的軟件穩(wěn)定性好、可移植性強,可以編制各種各樣的Windows應用程序。</p><p><b> 三、詳細設計</b></p><p><b> 1、系統(tǒng)流程圖</b&
20、gt;</p><p><b> 2、界面設計</b></p><p> 主界面:在此界面用戶可以選擇要操作的選項,回車之后即可進入相關的頁面進行操作(例如:選擇1 ,即可進入輸入學生數據頁面)</p><p> 在本界面里用戶可以輸入學生相關的信息數據,按照提示進行操作即可,例如:</p><p> 所有操作均
21、有提示語,比較人性化的管理,易懂,簡單。</p><p><b> 3、大概設計模塊</b></p><p> ?。?)先編入系統(tǒng)所需的庫函數,從而使程序可運行。</p><p> #include<iostream.h></p><p> #include<stdlib.h></p&
22、gt;<p> #include<iomanip.h>//主要是對cin,cout之類的一些操縱運算,是I/O流控制頭文件。 </p><p> #include <conio.h> //文件和標準控制臺的輸入輸出</p><p> #include<stdio.h> </p><p> Main()函數的設
23、計</p><p> 在main()函數中主要運用do-while循環(huán)語句和switch()-case選擇判斷語句來調用相關</p><p> 功能模塊。系統(tǒng)的運行是在一個永真的循環(huán)里進行的,只有在主界面并選擇“退出”時,才會跳出永真循環(huán),并退出程序。</p><p><b> 主界面的設計</b></p><p>
24、; 在主界面中包括“①輸入學生信息并保存到文件 ②讀取文件并輸出學生信息 ③按學號及學期查詢 ④按姓名及學期查詢 ⑤按學號及學期修改信息 ⑥插入信息 ⑦按學號及學期刪除信息 ⑧按數據結構降序(冒泡)排序 ⑨按總分降序(選擇)排序 ⑩統(tǒng)計各科成績的總分和平均分 11退出”等全部的功能,之所以設計這麼一個主界面,一是因為能使用戶對程序操作的流程更加清晰簡明,二是保證了用戶同時只能對一個文件進行操作系統(tǒng)的要求,保證了系統(tǒng)不會打開文件紊亂或者
25、出現致命的錯誤。每個函數體如下:</p><p> Void main(); //主函數</p><p> void input(Student *r); //輸入學生信息及數據</p><p> void output(Student *r); //輸出學生信息及數據</p><p>
26、 void searchnum(Student *r); //按學號及學期查找學生信息</p><p> void searchname(Student *r); //按姓名及學期查找學生信息</p><p> void change(Student *r); //按學號及學期修改學生信息</p><p> Student *insert(S
27、tudent *r); //插入學生信息</p><p> void shanchu(Student *r); //按學號及學期刪除循聲信息</p><p> void maopao(Student *r); //按數據結構降序(冒泡)排序</p><p> void xuanze(Student *r); //按總分降序(選
28、擇)排序</p><p> void tongji(Student *r); //統(tǒng)計各科總分和平均分信息</p><p><b> 4、詳細設計思想</b></p><p><b> ?。?)確定語言算法</b></p><p> 由于之前都沒有做過類似的設計,所以一時間不能夠確
29、定到底使用何種語言來設計本系統(tǒng),所以在網上看了一些其他人設計的程序,鏈表的、數組的,C++的,各種各樣的,也不知如何選擇,但是仔細地看了其中的設計思想,最終還是用C++和指針數組的來做,一是覺得本人對鏈表掌握的不是很熟練,那么在設計過程中容易產生不能理解的錯誤,耽誤時間,二是想運用C++,可以鞏固一下所學的數據結構的知識,之前做實驗的時候一直用C來做,都沒怎么用所學的知識,這時候想練練。就這樣確定了整體的結構算法。</p>
30、<p> 確定程序主要功能模塊</p><p> 這個就比較簡單了,主要是根據系統(tǒng)設計的說明及要求來設計,從而設計了十大功能模塊,有文件操作,有系統(tǒng)維護功能,排序和統(tǒng)計功能,有輸入輸出等基本功能,比較人性化,添加了較多的提示語。這個程序的主要功能時輸入學生的學號,姓名,學期和三科成績來對其進行存儲,在存儲后可以對學生的成績按學號及學期或姓名及學期來進行查詢,同時輸出此同學的平均分及總分,之后可以對
31、某個同學的成績進行各種操作,例如修改,刪除等,同時還可以對學生們的成績按照總分或單科成績排序,在整個過程中所做的操作都會保存到"student.txt"文件中并顯示。</p><p><b> 系統(tǒng)結構體的設計</b></p><p> struct Student //結構體</p><p><b> {&
32、lt;/b></p><p> int term;//學期</p><p> int num;//學號</p><p> char name[12];//姓名</p><p> float mark1;//成績</p><p> float mark2;</p><p> fl
33、oat mark3;</p><p> float sum;//總分</p><p> float average;//平均分</p><p><b> };</b></p><p> Student結構體說明表</p><p><b> 各功能模塊的設計</b>&
34、lt;/p><p> ******主函數模塊</p><p> 用函數void main()來實現</p><p> 主要是來顯示主菜單,使用戶選擇操作。首先定義一個指針數組(全局使用)Student *p=(Student *)new Student[num];在此處num是指學生個數,并不是學號,之前有定義的(不要弄混了),在這里應用了do-while和swi
35、tch-case語句來進行選擇,是個比較簡單實現的模塊。最后若選擇“11”則是保存記錄并退出永真循環(huán)。</p><p> ******輸入學生記錄模塊</p><p> 用函數void input(Student *r); 來實現</p><p> 主要功能用來對學生的成績進行收集和輸入。首先會有個提示“輸入最初要求的學生數”,之后跳出主菜單,選擇"
36、1",進入輸入模塊輸入所需學生個數的學生信息,比如學期,學號,姓名,成績等。輸完之后會自動跳出主菜單,根據主菜單來在此基礎上進行操作。期間會有一些提示語,按此操作即可。根據if和for語句來判定期間是否有重復學號輸入,在本操作中,允許有重復學生姓名出現。在此模塊中,用到了文件操作的指針FILE *fp;同時也用到了一個控制變量t,它是用來判定的條件變量,t=1表示找到了與之重復的學號,t=0表示未出現重復學號。在此期間會根據語
37、句算出總分和平均分,并默認按學號排序保存到文件中去。之后返回主菜單。</p><p><b> 寫文件操作代碼:</b></p><p> if((fp=fopen("student.txt","w"))==NULL) {</p><p> cout<<"文件不能打開"
38、;<<endl;</p><p><b> exit(0); </b></p><p><b> }</b></p><p> for(n=0;n<i;n++){</p><p> fprintf(fp,"%d %s %.1f %.1f %.1f
39、 %d %.1f %.1f",r[n].num,r[n].name,r[n].mark1,r[n].mark2,r[n].mark3,r[n].term,r[n].sum,r[n].average);</p><p> fprintf(fp,"\n");</p><p><b> }</b></p><p
40、> fclose(fp);</p><p> cout<<"文件已經寫入"<<endl;</p><p> ******顯示學生記錄模塊</p><p> 用函數void output(Student *r);來實現</p><p> 主要功能是用來顯示學生的信息進行輸出。在系統(tǒng)已經
41、錄入了學生資料的前提下,只用該功能可以顯示學生的信息資料等等。同時也會自動跳出主菜單進行后續(xù)操作。主要的程序代碼就是從文件的讀操作和界面顯示操作。其中stew()指的是兩字節(jié)之間的間隔,在括號中填入該有的數字就會有相應的間隔,從而使輸出有一定的美感。</p><p><b> 讀文件操作代碼:</b></p><p> if((fp=fopen("stu
42、dent.txt","r"))==NULL) {</p><p> cout<<"文件不能打開"<<endl;</p><p><b> exit(0); </b></p><p><b> }</b></p><p>
43、 for(int n=0;n<num;n++){</p><p> fscanf(fp,"%d%s%f%f%f%d%f%f",&r[n].num,r[n].name,&r[n].mark1,&r[n].mark2,&r[n].mark3,&r[n].term,&r[n].sum,&r[n].average);</p>
44、<p><b> }</b></p><p> fclose(fp);</p><p> cout<<"文件已經讀入"<<endl;</p><p> ******插入學生資料模塊</p><p> 用函數Student *insert(Student
45、*r);來實現</p><p> 主要功能是用來添加學生資料,成績。若顯示時沒有此學生的信息,就可以使用本模塊來進行添加。在此模塊代碼中定義了另一個指針數組:Student *y=(Student *)new Student[num+1];用來存放新添加的學生記錄。再利用for循環(huán)進行輸入新學生記錄,for(m=0;m<num;m++) {y[m]=r[m];}先將指針數組r中的內容賦給y,之后添加語句r
46、=y;將y的地址送給r,這樣可以保證新輸入的記錄可以在全程序中使用,使其變成全局變量,這樣也可以將新輸入的記錄保存到文件中去,最后會有一個提示語句cout<<"是否繼續(xù)輸入?(繼續(xù),輸入y,否則輸入其他)"<<endl;若輸入y則繼續(xù)輸入,否則將返回主菜單,本模塊功能到此結束。</p><p> ******按學號及學期來查找學生記錄模塊</p><
47、;p> 用函數void searchnum(Student *r);來實現</p><p> 主要功能時用來查找學生記錄。首先會有提示輸入學號及學期,再用for循環(huán)語句和if判斷語句來進行查找,if(r[m].num[0]==n[0]&&r[m].term==k)若找到則顯示學生記錄并跳出循環(huán);if(r[m].num[0]!=n[0]&&r[m].term!=k) 若沒有
48、則提示</p><p> "該學號不存在,或沒有這個學期的成績!"。</p><p> ******按姓名及學期來查找學生記錄模塊</p><p> 用函數void searchname(Student *r) 來實現</p><p> 主要功能也是用來查找學生記錄的。首先會有提示輸入姓名及學期,再用for循環(huán)語句
49、和if判斷語句來進行查找,if(r[m].name[0]==n[0]&&r[m].term==k)若找到則顯示學生記錄并跳出循環(huán);if(r[m].name[0]!=n[0]&&r[m].term!=k) 若沒有則提示</p><p> "該姓名不存在,或沒有這個學期的成績!"。</p><p> ******-查找輸出語句實現的代碼如
50、下:</p><p> cout<<"學號"<<setw(6)<<"姓名"<<setw(10)<<"高等數學"<<setw(10)<<"數據結構"<<setw(10)<<"組成原理"<<setw
51、(6)<<"學期"<<setw(6)<<"總分"<<setw(8)<<"平均分"<<endl;</p><p> cout<<r[m].num<<setw(6)<<r[m].name<<setw(7)<<r[m].mark
52、1<<setw(10)<<r[m].mark2<<setw(10)<<r[m].mark3<<setw(8)<<r[m].term<<setw(6)<<r[m].sum<<setw(8)<<r[m].average<<endl;</p><p> ******修改學生記錄模塊<
53、;/p><p> 用函數void change(Student *r)來實現</p><p> 主要功能是用來修改學生記錄。首先也要有個判斷語句,來看看要修給的學生是否存在,這個是通過學號及學期來判斷的(學號是不會有重復的),這里會有提示輸入學號及學期,之后是for和if語句,if(r[m].num==n&&r[m].term==k)若存在則先輸出修改之前的信息,查看是否正
54、確。若正確,則修改此學生記錄,這里有個while循環(huán)語句,和switch-case選擇語句,用來選擇修改哪科成績,和是否進行再修改記錄(通過選擇Y或y來實現)。最后將修改過后的記錄保存到文件中去,并輸出提示"文件已修改并寫入"。</p><p> ******按學號及學期刪除學生記錄</p><p> 用函數void shanchu(Student *r)來實現&l
55、t;/p><p> 主要功能是用來刪除學生記錄。首先有個度文件的操作,之后會有判斷語句,根據所輸入的學號及學期,來顯示刪除前的信息記錄,添加for循環(huán)語句,循環(huán)把后一位的信息提前一位,整體數量減一,來進行全局變量的修改,之后再把修改過后的信息記錄保存到文件中去。在現實中會有由于某些原因而不在學校的同學的記錄,這時候就要對其記錄進行刪除操作,這樣可以使系統(tǒng)及時更新并得到優(yōu)化。</p><p>
56、 ******按數據結構成績(冒泡)降序排序模塊</p><p> 用函數void maopao(Student *r)來實現</p><p> 主要功能時是用來對學生的記錄來按單科成績進行排序。這樣方便對某科成績有個大致的了解。首先會有一個讀文件操作,為排序做基礎。</p><p> 本排序使用冒泡排序。它有兩個優(yōu)點:一是“編程復雜度”很低,很容易寫出代碼
57、;二是具有穩(wěn)定性,這里的穩(wěn)定性是指原序列中相同兩元素的相對順序仍然保持到排序后的序列。冒泡排序時進過n-1趟子排序完成的,第i趟子排序從第1個數至第n+1個數,若第i個數比后一個數大(則升序,小則降序。本程序一律采用降序)則交換兩數。本程序中冒泡排序代碼如下:</p><p> for(int k=0;k<num-1;k++){</p><p> for(int m=0;m<
58、;num-k;m++){ </p><p> Student max;</p><p> if(r[m].mark2<r[m+1].mark2) {</p><p> max=r[m+1];</p><p> r[m+1]=r[m];</p><p><b> r[m]=max;</b&
59、gt;</p><p><b> } </b></p><p><b> }</b></p><p><b> }</b></p><p> cout<<"排序完畢"<<endl;</p><p>
60、 排序之后,將排序之后的結果寫入文件,再打開文件的時候,里面顯示的就是按單科成績排序后的結果。</p><p> ******按總分(選擇)降序排序</p><p> 用函數void xuanze(Student *r)來實現</p><p> 主要功能時是用來對學生的記錄來按總分成績進行排序。這樣方便對學生總體有個大致的了解。首先會有一個讀文件操作,為排序做
61、基礎。</p><p> 本排序使用選擇排序。其基本思想是:n個記錄的文件的直接選擇排序可進過n-1趟直接選擇排序得到有序結果:①初始狀態(tài),無</p><p> 序區(qū)為R[1..n],有序區(qū)為空。②第一趟排序 在無序區(qū)R[1..n]中選出關鍵字最小的記錄R[k],將它與無序區(qū)的第一個記錄R[1]交換,使R[1..n]和R[2..n]分別變?yōu)橛涗泜€數增加1個的新有序區(qū)記錄和記錄數減少
62、1個的新無序區(qū)。 ..... ③第i趟排序 第i唐排序開始時,當前有序區(qū)和無序區(qū)分別為R[1..i-1]和R(1≤i≤n-1)。該趟排序從當前無序區(qū)中選出關鍵字最小的記錄R[k],將它與無序區(qū)的第一個記錄與R交換,使R[1..i]和R分別變成為記錄個數增加1個的新有序區(qū)和記錄個數減少1個的新無序區(qū)。 這樣,n個記錄的文件的直接選擇排序可經過n-1趟直接選擇排序得到有序結果。本程序中選擇排序代碼如下:</p>
63、<p> for(int i=0;i<num;i++){</p><p> int max=i;</p><p> for(int j=i;j<num;j++){</p><p> if(r[max].sum<r[j].sum){</p><p><b> max=j;</b>&l
64、t;/p><p><b> }</b></p><p><b> }</b></p><p> Student temp;</p><p> temp=r[max];</p><p> r[max]=r[i];</p><p> r[i]=te
65、mp;</p><p><b> }</b></p><p> cout<<"排序完畢"<<endl;</p><p> 排序之后,將排序之后的結果寫入文件,再打開文件的時候,里面顯示的就是按單科成績排序后的結果。</p><p> ******統(tǒng)計各科總分及平均分模塊
66、</p><p> 用函數void tongji(Student *r)來實現</p><p> 主要功能是計算總分和各科平均分。代碼比較容易實現,計算完之后將總分保存到文件中即可。</p><p> *****以上就是本程序的詳細設計及基本思想*****</p><p> 所遇到的問題和分析解決</p><p&g
67、t;<b> 存在的不足</b></p><p> 本學生成績管理系統(tǒng)由十大模塊組成,每個模塊相互聯(lián)系又相互獨立。這個學生成績管理系統(tǒng)存在著很多不足之處,由于自己本身編程能力的問題,這個系統(tǒng)可以實現的功能非常有限。只能實現學生管理系統(tǒng)最基本的功能,可以進行簡單的輸入、輸出學生資料,查詢和修改學生信息,能直接從文件中讀入數據,能對系統(tǒng)所作的修改、操作進行保存等。而且在每個模塊也有不足的地方
68、,比如在輸入學生資料時,對每個信息項沒有嚴格的規(guī)定,可以輸入任何的字符。這有待以后努力,更詳盡的實現模塊的功能。</p><p> do-while語句的位置問題</p><p> 在修改學生記錄此模塊中,若循環(huán)語句的位置不對那么這個循環(huán)就會自動跳出,或變?yōu)閬y碼,不能實現原有的功能。所以要想清楚到底是在哪安放,按照邏輯思路找到相應的語句正確添加就行了。 </p>
69、<p><b> 指針數組的使用</b></p><p> 就是在插入學生記錄模塊中,另一個指針數組的定義,之前做的時候沒有注意到這點,結果所做的修改不能夠保存到文件,之后操作的時候也沒有顯示所做修改的記錄,之后找了資料看了之后才知道,是變量的問題,所以最后作了修改,加了一個另外的指針數組。</p><p> system('cls'
70、)的使用問題</p><p> 剛開始時對菜單的切換不是很了解,編寫的程序運行的時候是一豎行向下的,很影響使用者的視覺范圍,通過查詢一些資料得知了system('cls')的作用,能夠把一些暫時不用或不相關的信息通過清屏來處理。</p><p><b> 細節(jié)方面</b></p><p> 其實在有些細節(jié)方面還是要特別注意
71、啊,比如分號的添加,<<與>>的方向問題,函數的返回值等問題,雖然容易改掉,但是很容易養(yǎng)成不好的習慣,而且還會浪費時間,所以在一開始寫的時候就要很仔細,這樣才能保證程序編的精細,同時若出現很多這樣的錯誤的話,在編寫程序的時候也會心里煩的,所以在編程的時候要認真仔細。</p><p><b> 文件的寫入與讀出</b></p><p> 剛開
72、始時對文件的操作不是很明白,一直不能很好的操作文件,直到最后驗收的時候,仍舊出現了嚴重的問題,就是對已經存在的文件讀取問題,通過"讀取文件并輸出學生信息",將數據從文件中讀取,但是不能夠正常的讀出,最后把讀文件的操作語句進行仔細檢查后,發(fā)現語句的順序有點問題,把fscanf()語句進行再修改后就能夠正常的讀取文件了。</p><p><b> 內存的分配問題</b>&l
73、t;/p><p> 對于初學者的話對內存的分配和釋放問題是比較抽象的和模糊的問題,在排序是之前就出現了交換數據困難的問題,以及內存分配空間繁瑣釋放空間不及時的問題,造成空間的浪費,使得程序運行時效率較低,因此最后采用了順序存儲記錄的方式,這就能改變前面所出現的問題。</p><p><b> 較小的問題方面</b></p><p> 其余的就
74、沒什么比較大的問題了,基本上只要細心一點的話就可以正確調試了。</p><p><b> 系統(tǒng)特色及關鍵技術</b></p><p> 其實在本程序的設計過程當中,沒有很吸引人的關鍵技術,因為本人的C語言或C++語言都不是學的很好,所以當初設計的時候就只是想把功能都實現就好了,盡可能的把所要求的功能都編進程序,這樣就覺得很滿足了。所以都是設計的比較簡單易懂的語言,
75、這樣自己能夠更明白一些,所以就沒有時間去細細地去設計自己的程序。本程序要說有什么值得說的,那就只有人性化這點了,在設計成學的時候,因為自己怕弄混了,所以添加了很詳盡的提示,這樣在編程的過程中或調試的時候都能夠比較快的運行。還有就是盡可能的應用了do-while語句和switch-case語句,這兩個語句在之前不是很常用,所以在這個程序中試煉了一下,雖然在編寫的過程中總是出錯,但還是成功的用好了,也是程序有條理一些。我也知道這些東西別人可
76、能比我弄得還要好,但是我在我所學的知識中成功的應用了這些,我覺得就是好事,就是進步。</p><p><b> 結論及心得體會</b></p><p> 一周多的課程設計,終于成功的驗收了,雖然有些疲憊,但還是有很多的收獲的,像計算機組成原理的課設一樣,我又一次鞏固了所學到的知識,之前的學習只是停留在理論基礎上,現在自己動手操作試驗后,才是真正的理解及體會。C++
77、也學了近一年,有很多知識都是似懂非懂,通過平時上機操作,自己也了解了一些,但讓我有了更深的理解和更好的認識,則是在這次的課設上,之前的困惑也通過這次的課設解決了一些,雖然還是不能夠全面的理解,但是有進步就很高興。</p><p> 在課程設計之前,因為有了綜合實驗的經驗與教訓,明白了寫代碼這一步是非常重要的,因為當你把代碼輸進去之后,并編譯讓其運行,發(fā)現通過不了,再來檢查出問題,是很費費力的事情,因此分析和規(guī)劃
78、代碼是很重要的,最重要的是要把邏輯結構寫好,這樣就不會出現大問題,寫代碼就要先找出核心的內容,用多種方法來實現核心部分,這樣可以盡可能的避免發(fā)現邏輯或編譯不支持的錯誤。</p><p> 通過本次論文設計,我初步學會了論文設計的基本方法,學會了怎樣去借鑒別人的方法和經驗,知道了如何整合資料和處理這些資料的能力,這位以后做畢設的論文打下了基礎,使我感覺比較好的是有一種成功的喜悅,雖然在編譯的時候會經常因為一些小的
79、錯誤而心煩意亂,但是也不失為一件好事,失敗的越多積累的經驗越豐富,對人的考驗也比較多,那么在最后編譯成功時的喜悅就越濃烈,也是自己的能力有了進一步的提高。由于知識和經驗的不足,這個程序編寫的不是很盡如人意,但是融合了自己的心血,就覺得是最好的,所以在以后還是需要較多的努力的,還是會在以后的學習過程中不斷地提高和改進的。</p><p><b> 附錄(源代碼)</b></p>
80、<p> #include<iostream.h></p><p> #include<stdlib.h></p><p> #include<iomanip.h>//主要是對cin,cout之類的一些操縱運算,是I/O流控制頭文件。 </p><p> #include <conio.h> //文
81、件和標準控制臺的輸入輸出</p><p> #include<stdio.h> </p><p> struct Student //結構體</p><p><b> {</b></p><p> int term;//學期</p><p> int num;//學號<
82、/p><p> char name[12];//姓名</p><p> float mark1;//成績</p><p> float mark2;</p><p> float mark3;</p><p> float sum;//總分</p><p> float average;
83、//平均分</p><p><b> };</b></p><p> int num=0;</p><p> void input(Student *r); //輸入</p><p> void output(Student *r); //輸出</p><p> v
84、oid searchnum(Student *r); //按學號及學期查找</p><p> void searchname(Student *r); //按姓名及學期查找</p><p> void change(Student *r); //按學號及學期修改信息</p><p> Student *insert(Student *r
85、); //插入信息</p><p> void shanchu(Student *r); //按學號及學期刪除信息</p><p> void maopao(Student *r); //按數據結構降序(冒泡)排序</p><p> void xuanze(Student *r); //按總分降序(選擇)排序</p&
86、gt;<p> void tongji(Student *r); //統(tǒng)計各科總分和平均分信息</p><p> void main()</p><p><b> {</b></p><p> cout<<"輸入學生的個數:";</p><p><b&
87、gt; cin>>num;</b></p><p> Student *p=(Student *)new Student[num];//定義指針數組,存放學生個數</p><p><b> int m;</b></p><p><b> do{</b></p><p>
88、; cout<<endl;</p><p> cout<<endl;</p><p> cout<<"\t*************************菜單欄**********************************\n"<<endl;</p><p> cout<<
89、;"\t* 1 輸入學生信息并保存到文件 2 讀取文件并輸出學生信息 *"<<endl;</p><p> cout<<"\t* 3 按學號及學期查詢 4 按姓名及學期查詢 *"<<endl;</p><p> cout<<&quo
90、t;\t* 5 按學號及學期修改信息 6 插入信息 *"<<endl;</p><p> cout<<"\t* 7 按學號及學期刪除信息 8 按數據結構降序(冒泡)排序 *"<<endl;</p><p> cout<<"
91、;\t* 9 按總分降序(選擇)排序 10 統(tǒng)計各科成績的總分和平均分 *"<<endl;</p><p> cout<<"\t* 11 退出 *"<<endl;</p><p> cout<
92、;<"\t*****************************************************************\n"<<endl;</p><p> cout<<"請選擇:";</p><p><b> cin>>m;</b></p>&l
93、t;p> switch(m){</p><p><b> case 1: </b></p><p><b> input(p);</b></p><p><b> break;</b></p><p><b> case 2:</b><
94、;/p><p> output(p);</p><p><b> break;</b></p><p><b> case 3: </b></p><p> searchnum(p);</p><p><b> break;</b></p&g
95、t;<p><b> case 4: </b></p><p> searchname(p);</p><p><b> break;</b></p><p><b> case 5: </b></p><p> change(p);</p>
96、<p><b> break;</b></p><p><b> case 6: </b></p><p> p=insert(p);</p><p><b> break;</b></p><p><b> case 7: </b>
97、;</p><p> shanchu(p);</p><p><b> break;</b></p><p><b> case 8: </b></p><p> maopao(p);</p><p><b> break;</b></p
98、><p><b> case 9:</b></p><p> xuanze(p);</p><p><b> break;</b></p><p><b> case 10: </b></p><p> tongji(p);</p>
99、<p><b> break;</b></p><p><b> case 11:</b></p><p><b> break;</b></p><p><b> }</b></p><p> }while(m!=11); <
100、;/p><p><b> }</b></p><p> void input(Student *r) //輸入信息</p><p><b> {</b></p><p><b> FILE *fp;</b></p><p><b>
101、int n=0;</b></p><p><b> int i;</b></p><p> int t=0; //t為控制標量,1為找到,0為未找到 </p><p> cout<<endl<<"========>> 請輸入學生信息 <<========&
102、quot;<<endl;</p><p> for(i=0;i<num;i++){</p><p> cout<<"請輸入學期:";</p><p> cin>>r[i].term;</p><p> cout<<"請輸入第"<<
103、i+1<<"個人的學號:";</p><p> cin>>r[i].num; </p><p><b> if(i>=1){</b></p><p> for(n=0;n<i;n++){</p><p> if(r[n].num==r[i].num){
104、 </p><p> cout<<"該學號已存在??!"<<endl;</p><p><b> t=1;</b></p><p><b> }</b></p><p><b> }</b></p><p&g
105、t;<b> }</b></p><p> if(t==1){//表示有重復</p><p><b> i--;</b></p><p><b> t=0;</b></p><p><b> continue;</b></p>&l
106、t;p><b> }</b></p><p> cout<<"請輸入姓名:";</p><p> cin>>r[i].name;</p><p> cout<<"請輸入 高等數學 成績:";</p><p> cin>>
107、;r[i].mark1;</p><p> cout<<"請輸入 數據結構 成績:";</p><p> cin>>r[i].mark2;</p><p> cout<<"請輸入 組成原理 成績:";</p><p> cin>>r[i].mark
108、3;</p><p> r[i].sum=r[i].mark1+r[i].mark2+r[i].mark3;</p><p> r[i].average=(r[i].mark1+r[i].mark2+r[i].mark3)/3;</p><p><b> }</b></p><p> if((fp=fopen(&
109、quot;student.txt","w"))==NULL) {</p><p> cout<<"文件不能打開"<<endl;</p><p><b> exit(0); </b></p><p><b> }</b></p>&
110、lt;p> for(n=0;n<i;n++){</p><p> fprintf(fp,"%d %s %.1f %.1f %.1f %d %.1f %.1f",r[n].num,r[n].name,r[n].mark1,r[n].mark2,r[n].mark3,r[n].term,r[n].sum,r[n].average);</p>
111、<p> fprintf(fp,"\n");</p><p><b> }</b></p><p> fclose(fp);</p><p> cout<<"文件已經寫入"<<endl;</p><p><b> }<
112、/b></p><p> void output(Student *r) //輸出信息</p><p><b> {</b></p><p><b> int m;</b></p><p> system("cls");</p><p>
113、 if(num>0){</p><p><b> FILE *fp;</b></p><p> if((fp=fopen("student.txt","r"))==NULL) {</p><p> cout<<"文件不能打開"<<endl;<
114、/p><p><b> exit(0); </b></p><p><b> }</b></p><p> for(int n=0;n<num;n++){fscanf(fp,"%d%s%f%f%f%d%f%f",&r[n].num,r[n].name,&r[n].mark1
115、,&r[n].mark2,&r[n].mark3,&r[n].term,&r[n].sum,&r[n].average);</p><p><b> }</b></p><p> fclose(fp);</p><p> cout<<"文件已經讀入"<<e
116、ndl;</p><p> cout<<"******************************學生信息如下**********************************"<<endl;</p><p> cout<<"學號"<<setw(6)<<"姓名"
117、<<setw(10)<<"高等數學"<<setw(10)<<"數據結構"<<setw(10)<<"組成原理"<<setw(6)<<"學期"<<setw(6)<<"總分"<<setw(8)<<&qu
118、ot;平均分"<<endl;</p><p> cout<<"---------------------------------------------------------------"<<endl;</p><p> for(m=0;m<num;m++){cout<<r[m].num<&
119、lt;setw(6)<<r[m].name<<setw(7)<<r[m].mark1<<setw(10)<<r[m].mark2<<setw(10)<<r[m].mark3<<setw(8)<<r[m].term<<setw(6)<<r[m].sum<<setw(6)<<r[m].a
120、verage<<endl;</p><p><b> }</b></p><p> cout<<"\0\0"<<endl;</p><p><b> }</b></p><p><b> else</b></
121、p><p> cout<<"未輸入任何信息?。?quot;<<endl;</p><p><b> }</b></p><p> void searchnum(Student *r) //按學號及學期查找</p><p><b> {</b></p&
122、gt;<p><b> int n,k;</b></p><p> system("cls");</p><p> if(num>0){</p><p> cout<<"請輸入要查找學生的學號:";</p><p><b> ci
123、n>>n;</b></p><p> cout<<"請輸入學期號:";</p><p><b> cin>>k;</b></p><p> for(int m=0;m<num;m++){</p><p> if(r[m].num==n&am
124、p;&r[m].term==k){//如果找到了輸出并跳出循環(huán)</p><p> cout<<endl;</p><p> cout<<"---------------------------要查找的信息如下--------------------------------"<<endl;</p><p&
125、gt; cout<<"學號"<<setw(6)<<"姓名"<<setw(10)<<"高等數學"<<setw(10)<<"數據結構"<<setw(10)<<"組成原理"<<setw(6)<<"學期&
126、quot;<<setw(6)<<"總分"<<setw(8)<<"平均分"<<endl;cout<<r[m].num<<setw(6)<<r[m].name<<setw(7)<<r[m].mark1<<setw(10)<<r[m].mark2<&
127、lt;setw(10)<<r[m].mark3<<setw(8)<<r[m].term<<setw(6)<<r[m].sum<<setw(8)<<r[m].average<<endl;</p><p><b> break;</b></p><p><b>
128、}</b></p><p><b> }</b></p><p> if(r[m].num!=n&&r[m].term!=k) //若沒找到提示不存在</p><p> cout<<"該學號不存在,或沒有這個學期的成績!"<<endl;</p><
129、;p><b> }</b></p><p><b> else</b></p><p> cout<<"未輸入任何信息?。?quot;<<endl;</p><p><b> }</b></p><p> void search
130、name(Student *r) //按姓名及學期查找</p><p><b> {</b></p><p> char n[12];</p><p><b> int k;</b></p><p> system("cls");</p><p&
131、gt; if(num>0){ //如果沒輸入就查找提示</p><p> cout<<"請輸入要查找學生的姓名:";</p><p><b> cin>>n;</b></p><p> cout<<"請輸入學期號:";</p><p&
132、gt;<b> cin>>k;</b></p><p> for(int m=0;m<num;m++){</p><p> if(r[m].name[0]==n[0]&&r[m].term==k){ //如果找到了輸出并跳出循環(huán)</p><p> cout<<endl;</p>
133、<p> cout<<"---------------------------要查找的信息如下--------------------------------"<<endl;</p><p> cout<<"學號"<<setw(6)<<"姓名"<<setw(10)&
134、lt;<"高等數學"<<setw(10)<<"數據結構"<<setw(10)<<"組成原理"<<setw(6)<<"學期"<<setw(6)<<"總分"<<setw(8)<<"平均分"<&
135、lt;endl;cout<<r[m].num<<setw(6)<<r[m].name<<setw(7)<<r[m].mark1<<setw(10)<<r[m].mark2<<setw(10)<<r[m].mark3<<setw(8)<<r[m].term<<setw(6)<<
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 學生成績管理系統(tǒng)課程設計報告
- 課程設計報告-學生成績管理系統(tǒng)
- 學生成績管理系統(tǒng)課程設計報告
- 學生成績管理系統(tǒng)課程設計報告
- 課程設計報告--學生成績管理系統(tǒng)
- 課程設計報告---學生成績管理系統(tǒng)
- 學生成績管理系統(tǒng)課程設計報告
- 學生成績管理系統(tǒng)課程設計報告
- 學生成績管理系統(tǒng)課程設計報告
- 《學生成績管理系統(tǒng)》課程設計報告
- vb學生成績管理系統(tǒng)課程設計報告
- java課程設計報告---學生成績管理系統(tǒng)
- 學生成績管理系統(tǒng)課程設計報告 (2)
- java學生成績管理系統(tǒng)課程設計報告
- java學生成績管理系統(tǒng)課程設計報告
- 學生成績管理系統(tǒng)課程設計報告 (3)
- c課程設計報告--學生成績管理系統(tǒng)
- java學生成績管理系統(tǒng)課程設計報告
- 學生成績管理系統(tǒng)課程設計報告.doc
- vfp課程設計報告---學生成績管理系統(tǒng)
評論
0/150
提交評論