學生成績管理系統(tǒng)--c語言課程設計_第1頁
已閱讀1頁,還剩34頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、<p>  C語言課程設計任務書</p><p>  題 目 學生成績管理系統(tǒng) </p><p>  起訖日期 2006年7月3日 至2006年8月6日</p><p>  學生姓名  專業(yè)班級 </p><p>  所在院系         &

2、lt;/p><p>  指導教師 職稱  教授   </p><p>  所在單位 軟件學院 </p><p>  2006年7月 1 日</p><p><b>  任務及要求:</b></p><p>  設計(研究

3、)內容和要求(包括設計或研究內容、主要指標與技術參數(shù),根據(jù)課題性質對學生提出具體要求)</p><p>  研究內容:學生成績管理 </p><p><b>  任務和要求:</b></p><p> ?。?).學習C語言基礎知識,掌握C語言編程和程序調試的基本技能。</p><p> ?。?).對指導教師下達的題目進行

4、系統(tǒng)分析。</p><p> ?。?).根據(jù)分析結果完成系統(tǒng)設計,包括詳細設計部分內容。</p><p> ?。?).編程:在計算機上實現(xiàn)題目的代碼實現(xiàn)。</p><p> ?。?).完成對該系統(tǒng)的測試和調試。</p><p> ?。?).寫出用戶使用說明報告。</p><p>  (7). 提交課程設計報告。<

5、/p><p><b>  (8).指標:</b></p><p>  要求完成課程設計報告4千字以上(約二、三十頁)</p><p>  軟件系統(tǒng)300行語句以上</p><p>  用戶使用說明書(3千漢字以上)</p><p>  2.原始依據(jù)(包括設計或論文的工作基礎、研究條件、應用環(huán)境、工作目

6、的等)</p><p>  了解C語言的基礎知識,有一定的語言編程基礎,能夠熟練運用C語言進行程序設計。通過用C語言完成的題目,提高用C語言解決實際問題的能力。</p><p><b>  3.參考文獻</b></p><p>  [1] 黃明等.21世紀進階輔導 C語言程序設計.大連理工大學出版社,2005</p><p&

7、gt;  [2] 馬靖善等.C語言程序設計.清華大學出版社,2005</p><p>  [3] 譚浩強.C語言程序設計(第二版).北京:高等教育出版社,2002</p><p><b>  指導教師簽字:</b></p><p><b>  教研室主任簽字:</b></p><p>  2006年

8、 7月1日</p><p><b>  摘 要</b></p><p>  利用所學過的C語言知識,采用結構化程序設計方法,設計一個學生成績管理檔案程序,該程序的主要功能為: 0將表格初始化,1建立學生成績表格,2從表中刪除原有紀錄,3顯示單鏈表中所有記錄,4按照姓名查找紀錄,5計算所有學生的總分和均分,6插入紀錄到表中,7復制文件,8將所有學生成績排序,9分類

9、合計,10退出。該系統(tǒng)功能完善,界面友好,短小經(jīng)用,使用方便,即使是不熟悉計算機也可以自如的使用該系統(tǒng)。通過上機調試運行與模擬操作,完成對學生成績的管理,減輕管理人員的勞動強度,提高一個學校的自動化管理水平。</p><p>  關鍵詞:學生成績管理;結構化程序設計;調試運行;功能完善</p><p><b>  目 錄</b></p><p>

10、;<b>  第一章 概述1</b></p><p><b>  1.1項目背景1</b></p><p><b>  1.2工作環(huán)境1</b></p><p>  第二章 系統(tǒng)分析2</p><p>  2.1系統(tǒng)需求分析2</p><p>

11、  2.2 系統(tǒng)功能分析2</p><p>  2.2.1模塊實現(xiàn)算法2</p><p>  2.2.2進入主菜單。3</p><p>  2.2.3 建立學生表格3</p><p>  2.2.4從表中刪除原有紀錄3</p><p>  2.2.5顯示單鏈表中所有記錄3</p><p&

12、gt;  2.2.6按照姓名查找紀錄3</p><p>  2.2.7計算所有學生的總分和均分4</p><p>  2.2.8插入紀錄到表中4</p><p>  2.2.9復制文件4</p><p>  2.2.10將所有學生成績排序5</p><p>  2.2.11分類合計:5</p>

13、<p>  2.2.12退出5</p><p>  第三章 總體設計6</p><p><b>  3.1軟件描述6</b></p><p><b>  3.2設計方法6</b></p><p><b>  3.3軟件結構6</b></p>

14、<p>  3.4文件及函數(shù)組成7</p><p>  第五章 使用說明10</p><p>  第六章 工作總結16</p><p>  參考文獻(參考書或論文或文章)17</p><p><b>  附錄 源代碼18</b></p><p><b>  第一章 概

15、述</b></p><p>  現(xiàn)今已步入高速發(fā)展的時代,電腦技術發(fā)展日新月異,時代潮流也不斷變革,競爭越發(fā)激烈,時間就是金錢,但是就是在一些瑣碎的事上面浪費了大量的時間,例如查詢資料之類.如果我們把浪費的時間用于其他方面,勢必會有更大的收益.應此需求,為使廣大教師掌握更多的時間,相應的開發(fā)出此軟件—學生成績管理軟件系統(tǒng).而編寫詳細設計說明書是軟件開發(fā)過程必不可少的部分,其目的是為了使開發(fā)人員在完成概

16、要設計說明書的基礎上完成概要設計規(guī)定的各項模塊的具體實現(xiàn)的設計工作。本軟件屬于綠色軟件, 適合任何層次的用戶, 因此本說明書的預期讀者范圍相當廣。</p><p><b>  1.1項目背景</b></p><p><b>  軟件名稱</b></p><p><b>  學生成績管理</b><

17、/p><p><b>  相關單位</b></p><p>  主要是學校用于學校的成績管理</p><p><b>  1.2工作環(huán)境</b></p><p>  A.一臺586 以上的微機及兼容</p><p>  B.內存16MB(最好32MB內存) </p>

18、<p>  C.VGA 彩顯一臺</p><p><b>  第二章 系統(tǒng)分析</b></p><p><b>  2.1系統(tǒng)需求分析</b></p><p>  隨著網(wǎng)絡經(jīng)濟時代的到來,社會飛速的發(fā)展,人們的生活發(fā)生著日新月異的變化,高新技術正驅趕著人們生活的腳步,人們對工作生活的要求也日益提高,特別是計算機

19、的應用及普及到經(jīng)濟和社會生活的各個領域。使原本的舊的管理方法越來越不適應現(xiàn)在社會的發(fā)展。許多人還停留在以前的手工操作,隨著各個學校的規(guī)模增大,有關學生成績管理工作所涉及的數(shù)據(jù)量越來越大,有的學校不得不靠增加人力、物力來進行學生成績管理,但手工管理具有效率底、,這大大地阻礙了人類經(jīng)濟的發(fā)展。為了適應現(xiàn)代社會人們高度強烈的時間觀念,用計算機對學校學生成績進行管理已逐步取代了傳統(tǒng)的管理方式。</p><p>  學生成

20、績查詢系統(tǒng)對學校加強學生成績管理有著極其重要的作用。由于各個大學都在持續(xù)擴招,學生的數(shù)量日益龐大,傳統(tǒng)的手工成績管理不僅工作量大,而且容易出現(xiàn)問題。從而需要對學生成績管理等工作方面提高精確度。</p><p>  經(jīng)過我對學校情況和師生需求的的具體分析,初步設計了一套有關“學生成績管理”的程序,希望可以幫助學校改善以往需求緊張的管理系統(tǒng),為廣大師生提供方便,節(jié)省時間,提高工作效率,從而樹立良好的辦學形象。<

21、/p><p><b>  學校具體需求分析</b></p><p>  學生:對各科成績的查詢及查看本班成績排名。</p><p>  老師:輸入并維護所教科目的學生成績,計算本科的成績排名、本科成績在班上的排名。</p><p>  班主任:輸入并維護本班的基本信息,對本班的各科成績匯總,計算各科成績的總分,排名,本班平均

22、分等需求。輸出學生的基本信息,各科的成績及各科成績的部分,各科成績的排名,總分的排名情況。</p><p>  教務處: 學校全體成員的信息管理,對考試科目,時間及對所考科目的編號等進行具體的管理,并對任課老師,班主任等輸入的信息進行存庫,對學生的信息進行必要的維護,可打印學生的所有信息。</p><p>  2.2 系統(tǒng)功能分析</p><p>  在本章中,我使

23、用模塊等分析法進行系統(tǒng)功能分析。</p><p>  2.2.1模塊實現(xiàn)算法,在進入主菜單前,如圖2-1所示:</p><p>  2-1進入主菜單模塊</p><p>  2.2.2進入主菜單,此時流程在3.4軟件結構會描述清楚。</p><p>  2.2.3 建立學生表格,算法實現(xiàn)模式,如圖2-2所示:</p><p

24、><b>  N返回主模塊</b></p><p>  Y </p><p><b>  N 返回主模塊</b></p><p><b>  Y</b></p><p><b>  Y任意鍵返回主模塊</b></p>

25、<p>  2-2建立學生表格模塊</p><p>  2.2.4從表中刪除原有紀錄模塊,算法,如圖2-3所示:</p><p><b>  N返回主模塊</b></p><p>  Y </p><p><b>  N 返回主模塊</b></p>

26、<p><b>  Y</b></p><p><b>  Y任意鍵返回主模塊</b></p><p>  2-3刪除原有紀錄模塊</p><p>  2.2.5顯示單鏈表中所有記錄模塊,算法,如圖3-4所示:</p><p><b>  N返回主模塊</b><

27、/p><p>  Y </p><p><b>  N 返回主模塊</b></p><p><b>  Y</b></p><p><b>  Y任意鍵返回主模塊</b></p><p><b>  2-4顯示紀錄模塊<

28、/b></p><p>  2.2.6按照姓名查找紀錄模塊,算法,如圖2-5所示:</p><p><b>  N返回主模塊</b></p><p>  Y </p><p><b>  N 返回主模塊</b></p><p><b> 

29、 Y</b></p><p><b>  Y任意鍵返回主模塊</b></p><p><b>  2-5查找模塊</b></p><p>  2.2.7計算所有學生的總分和均分模塊,算法,如圖2-6所示:</p><p><b>  N返回主模塊</b></p

30、><p>  Y </p><p><b>  Y任意鍵返回主模塊</b></p><p><b>  2-6計算模塊</b></p><p>  2.2.8插入紀錄到表中模塊,算法,如圖2-7所示:</p><p><b>  N返回主模塊<

31、;/b></p><p>  Y </p><p><b>  N 返回主模塊</b></p><p><b>  Y</b></p><p><b>  Y任意鍵返回主模塊</b></p><p><b>  2-

32、7插入紀錄模塊</b></p><p>  2.2.9復制文件模塊,算法,如圖2-8所示:</p><p><b>  N返回主模塊</b></p><p>  Y </p><p><b>  N 返回主模塊</b></p><p><

33、;b>  Y</b></p><p><b>  Y任意鍵返回主模塊</b></p><p><b>  2-8復制模塊</b></p><p>  2.2.10將所有學生成績排序模塊,算法,如圖2-9所示:</p><p><b>  N返回主模塊</b>&

34、lt;/p><p>  Y </p><p><b>  Y任意鍵返回主模塊</b></p><p><b>  2-9排序模塊</b></p><p>  2.2.11分類合計模塊,算法,如圖2-10所示:</p><p><b>  N返回主模

35、塊</b></p><p>  Y </p><p><b>  Y任意鍵返回主模塊</b></p><p>  2-10分類合計模塊</p><p>  2.2.12退出模塊,算法。</p><p><b>  第三章 總體設計</b>&l

36、t;/p><p><b>  3.1軟件描述</b></p><p>  該程序的主要功能為: 0將表格初始化,1建立學生成績表格,2從表中刪除原有紀錄,3顯示單鏈表中所有記錄,4按照姓名查找紀錄, 5計算所有學生的總分和均分,6插入紀錄到表中,7復制文件,8將所有學生成績排序, 9分類合計,10退出。另外,該程序主要調用了:I/O函數(shù)(stdio.h),其他說明(std

37、ib.h),字符串函數(shù)(string.h),屏幕操作函數(shù)(conio.h),內存操作函數(shù)(mem.h),字符操作函數(shù)(ctype.h),動態(tài)地址分配函數(shù)(alloc.h),定義常數(shù)。</p><p><b>  3.2設計方法</b></p><p>  本軟件采用傳統(tǒng)的軟件開發(fā)生命周期的方法,采用自定向下,逐步求精的結構化的軟件設計方法。</p>&l

38、t;p><b>  3.3軟件結構</b></p><p>  根據(jù)以上模塊可得到總體結構系統(tǒng)才層次圖,如圖3-1所示:</p><p>  3-1總體結構系統(tǒng)層次圖</p><p>  3.4文件及函數(shù)組成</p><p><b>  如表1-1所示:</b></p><

39、p><b>  表3-1 主要函數(shù)</b></p><p>  1.顯示內存動態(tài)記錄數(shù)據(jù)函數(shù)</p><p>  函數(shù)原型:void create()</p><p>  功能:顯示內存里的記錄</p><p>  參數(shù):記錄數(shù)組和記錄條數(shù)</p><p>  要求:報告是否有記錄及記錄成績

40、內容</p><p><b>  2.輸入信息函數(shù)</b></p><p>  函數(shù)原型:int inputs(char *prompt, char *s, int count)</p><p><b>  功能:添加記錄</b></p><p><b>  參數(shù):結構體數(shù)組.</b

41、></p><p>  要求: 如果內存已經(jīng)存在記錄.則將新記錄追加在記錄尾部,如果還沒有建立記錄鏈表,則建立鏈表并從尾部開始追加記錄.</p><p><b>  3.刪除記錄函數(shù)</b></p><p>  函數(shù)原型:int delete(STUDENT *h)</p><p>  功能:刪除內存鏈表中的指定結

42、點</p><p>  參數(shù):記錄數(shù)組和記錄條數(shù),成績</p><p><b>  要求:給出相關信息</b></p><p>  4.按序號顯示記錄函數(shù)</p><p>  函數(shù)原型:void print(STUDENT *h)</p><p>  功能:根據(jù)用戶需求輸出記錄</p>

43、<p>  要求:判斷內存中記錄的序號與輸入的是否相等,如果相等則輸出,否則關閉文件</p><p><b>  5.查找函數(shù)</b></p><p>  函數(shù)原型:int search()</p><p>  功能:根據(jù)用戶需要輸出記錄</p><p>  參數(shù):記錄數(shù)組和記錄成績以及姓名s</p&

44、gt;<p>  要求:判斷內存中記錄的名字與輸入的是否相等,如果相等則輸出,否則提前結束</p><p><b>  6.計算函數(shù)</b></p><p>  函數(shù)原型:int Computer(STUDENT *h)</p><p>  功能:根據(jù)用戶需要計算總分和學生平均成績</p><p><

45、b>  參數(shù):記錄數(shù)和計算</b></p><p>  要求:內存中記錄數(shù)進行相加和平均數(shù)運算</p><p><b>  7.插入記錄函數(shù)</b></p><p>  函數(shù)原型:int insert(STUDENT *h)</p><p>  功能:根據(jù)用戶指定將信息插入特定位置</p>

46、<p>  參數(shù):結構體數(shù)組和記錄數(shù)</p><p><b>  要求:輸入信息</b></p><p><b>  8.復制文件函數(shù)</b></p><p>  函數(shù)原型:void copy()</p><p><b>  功能:復制記錄</b></p>

47、;<p>  要求:判斷所要文件是否能打開,打不開則退出,能打開則讀出文件中記錄并復制</p><p><b>  9.排序函數(shù)</b></p><p>  函數(shù)原型:void sort(STUDENT *h)</p><p>  功能:將記錄進行排序</p><p>  參數(shù):結構體數(shù)組和記錄數(shù)</

48、p><p>  要求:比較內存中記錄,判斷大小并進行交換,交換后顯示排序成功</p><p><b>  10.分類合計函數(shù)</b></p><p>  函數(shù)原型:void Total(STUDENT *h)</p><p><b>  功能:分類存放 </b></p><p>

49、  參數(shù):結構體數(shù)組和記錄數(shù)</p><p>  要求:在內存中分類存放各班不同的記錄數(shù)和計算后得到的記錄數(shù)</p><p><b>  11.菜單函數(shù)</b></p><p>  函數(shù)原型:menu_select()</p><p><b>  功能:控制程序</b></p><

50、;p>  要求:管理菜單命令并完成初始化</p><p><b>  第四章 程序調試</b></p><p>  在設計該程序的時候我采用了結構化程序方法編輯,并在源代碼的基礎上添加了中文注釋。但是在該系統(tǒng)的編寫過程中仍然有許多錯誤,主要的有:注釋文字的排版,定義錯誤,句式的語法錯誤。</p><p>  在完善程序時,我將源代碼先打印

51、下來反復的捉摸和研究,力圖在上機運行時先改正一些低級錯誤.如缺少”;”之類.在仔細檢查之后,將源代碼上機調試—進行編譯,在編譯和連接過程中發(fā)現(xiàn)錯誤,屏幕上顯示了出錯信息,根據(jù)提示找到出錯的位置,加以改正……直到順利顯示我預期的。</p><p>  1、首先,在本次調試過程中我碰到了在上機前根本沒有想到的錯誤:在注釋的時候,注釋文字應寫在一起中間不能有中斷,不能再其中包含c語言的語句。否則會引起錯誤,例如格式不正

52、確或是多了字符等。</p><p>  2、缺少變量定義或是定義位置不正確;</p><p>  由于該程序相對來講稍有些長,前后有些變量很難聯(lián)系起來,但是在錯誤信息的提示下一般還是很是可以找到。不過需要注意的是在定義的時候有些函數(shù)使用同樣的變量名而表示不同的作用,因而使用要很小心,定義及定義的位置要特別留意。為減少這樣的錯誤我后來還是用不同的變量名來表示,結果引起的那些錯誤解決了。<

53、;/p><p>  3、句式的語法錯誤;</p><p>  大多的語法錯誤在通過書本參考下能夠修改。主要是平時看書不仔細、不太注意而產(chǎn)生的。如沒有注意具體數(shù)據(jù)使用是有一定的范圍限定;過分重視分號的重要性而在for、if、while語句中畫蛇添足加分號;在使用文件的時候忘記將文件先打開,對打開的方式與使用的情況不太注意而造成不匹配;還有漏掉形參的定義是值不能傳遞等等。這些語法錯誤有信息框的提示

54、一般是能夠排除的。</p><p>  編譯、連接的成功并不意味著程序的最終成功。</p><p>  邏輯上的錯誤機器不易檢查出來,這時需要對數(shù)據(jù)結果進行分析。這種錯誤的查找是最難的,需要編程序的人有相當?shù)哪托暮图毿娜グ褑栴}找出來。這也是本次程序編輯過程中碰到的最大的難題。往往運行之后得不到另人滿意的結果,此時解決的方法一則可以用“分段檢查”的方法,在程序的不同位置設幾個printf函數(shù)

55、語句,輸出有關變量的值,逐段往下檢查,或用debug進行調試,對檢查出的錯誤進行修改,當調試完畢將設置的printf都刪去。若在程序中找不到問題,則再來考慮算法是否邏輯嚴謹,再進行修改。如此循環(huán)往復,直到最后程序運行成功。在本次程序編輯過程中,我就是常遇到編譯能通過,能夠運行程序,但是總在輸入、刪除等操作完之后再想去看數(shù)據(jù)文件中存在的數(shù)據(jù)記錄的時候,卻一條記錄也顯示不出來,我懷疑是哪個對方對n變量的定義或使用出錯了,于是在每個主要函數(shù)的

56、操作過程中添加了printf語句用來顯示n的變化,例如在執(zhí)行某個函數(shù)前添加插入語句顯示n的起始值,在執(zhí)行完該個函數(shù)后再添加插入語句顯示此時n的結果值,觀察n的變化是否正確,如果錯誤了,也就說明該函數(shù)編寫過程有錯。諸如這樣的調試方法,不斷縮小檢查范圍,最后將錯誤找到,進行修</p><p><b>  第五章 使用說明</b></p><p>  首先進入界面時,根據(jù)屏

57、幕上的提示press any key enter menu……即是按任意鍵均可進入主菜單,考慮到學生成績大多由老師輸入和調用,所以這里對使用者沒有要求也就沒有添加密碼的必要。</p><p>  在進入主菜單時可以看到這樣的畫面,如圖4-1所示:</p><p><b>  4-1主菜單</b></p><p>  從0到10共有11個功能鍵。

58、此時應該根據(jù)提示”Enter your choice (0-10):”選擇自己需要用的功能,例如:在提示后按1再回車(Enter鍵)的話就會進入編輯。</p><p>  在主菜單上的11個功能分別是:</p><p>  0 init list將表格初始化:使用0后,系統(tǒng)會將原有的一切記錄全部刪去,所有的恢復到位使用時。一切在主菜單上完成。</p><p>  1

59、 Enter list建立學生成績表格:使用1后,在界面上會要求你輸入學號no,姓名name 和成績score1、2、3。如果已經(jīng)輸入完畢只要在下一個no后輸入!再按回車鍵即可,此時就會回到主菜單,如圖4-2所示:</p><p><b>  4-2輸入界面</b></p><p>  2 Delete a record from list從表中刪除原有紀錄:使用2

60、后,會進入子界面,提示語會告訴你輸入你要刪除的信息的學生的學號,然后會出現(xiàn)“ list no ** student”這就表示刪除成功,如果沒有這個學生的信息則會跳過步執(zhí)行但是還是會輸出上述的句子,如圖4-3所示:</p><p><b>  4-3顯示刪除界面</b></p><p>  3 print list顯示單鏈表中所有記錄:如果是在執(zhí)行完5以后,那么總分和均

61、分一欄就不會空白,而是會輸出計算后的數(shù)據(jù),如圖4-4所示:</p><p><b>  4-4打印數(shù)出界面</b></p><p>  4 Search record from list按照姓名查找紀錄:根據(jù)提示”please enter students’name for search”輸入學生的拼音拼寫的姓名,如圖4-5所示:</p><p&g

62、t;<b>  4-5查找界面</b></p><p>  5 compute the score計算所有學生的總分和均分:按5后,系統(tǒng)會自動計算然后輸出結果,如圖4-6所示:</p><p><b>  4-6計算界面</b></p><p>  6 insert record to list插入紀錄到表中:使用6 時,

63、要輸入你想插到哪一個學生前,只需輸入他的學號。然后,在提示語的提醒下輸入要插入學生的學號,姓名和成績。然后再進入打印界面,此時可以看到已經(jīng)將09插入到02 前。如圖4-7所示:</p><p><b>  4-7插入后界面</b></p><p>  7 copy the file to new file復制文件:執(zhí)行完7后,會根據(jù)使用者輸入的地址和命名生成文本文檔存

64、儲。</p><p>  8 sort to make new file將所有學生成績排序:在完成后,會出現(xiàn)”sort success!”</p><p>  如果想看結果的話,可以在執(zhí)行完這一步后在執(zhí)行3,這樣就可以看到排序后的結果。</p><p>  9 total on nomber分類合計,如圖4-9所示:</p><p><

65、b>  4-9分類合計界面</b></p><p>  10 Quit退出模塊,在主菜單上實行。如圖4-10所示:</p><p><b>  4-10退出界面</b></p><p><b>  第六章 工作總結</b></p><p>  在這次的編程過程中,我不僅在C語言的學

66、習上有了很大的提高而且也培養(yǎng)了我的毅力、耐心、決心和學習能力。短短的兩周,我自己都不敢相信可以弄好一個對我而言一個大而功能相對而言還可以的程序。</p><p>  但是不得不說在這個程序中仍然有許多的缺陷,諸如:計算均分時只能計算三門的總均分;無法將文件以文檔或是表格形式存儲;排序、刪除等必須以一種形式先查找學生信息然后再實行操作并不多樣化??傊?,在這個過程中我還面對了程序無法執(zhí)行,改錯時怎么也找不到錯誤在哪里

67、的困境;但我還是在老師和同學們的幫助下完成了這個程序。</p><p>  可以說我的心情是相當?shù)募樱嘈庞辛诉@樣的經(jīng)歷后我能夠更加嫻熟的面對各種情況。</p><p>  注:課程設計以來的感想、心得、經(jīng)驗、收獲、有待改進的方面。不超過一頁。</p><p>  參考文獻(參考書或論文或文章)</p><p>  [1] 黃明等.21世紀

68、進階輔導 C語言程序設計.大連理工大學出版社,2005:45—208</p><p>  [2] 馬靖善等.C語言程序設計.清華大學出版社,2005:23—145</p><p><b>  附錄 源代碼</b></p><p>  #include "stdio.h" </p><p>  #

69、include "stdlib.h" </p><p>  #include "string.h" </p><p>  #include "conio.h" </p><p>  #include "mem.h" </p><p>  #inclu

70、de "ctype.h" </p><p>  #include "alloc.h" </p><p>  #define N 3 </p><p>  typedef struct z1 </p><p><b>  {</b></p><

71、p>  char no[11];</p><p>  char name[20];</p><p>  int score[N];</p><p>  float sum;</p><p>  float average;</p><p>  int order;</p><p>  st

72、ruct z1 *next;</p><p><b>  }STUDENT;</b></p><p>  STUDENT *init(); </p><p>  STUDENT *create(); </p><p>  STUDENT *delete(STUDENT *h); </p>

73、<p>  void print(STUDENT *h); </p><p>  void search(STUDENT *h); </p><p>  void save(STUDENT *h); </p><p>  STUDENT *load(); </p><p>  void compute

74、r(STUDENT *h); </p><p>  STUDENT *insert(STUDENT *h); </p><p>  void append(); </p><p>  void copy(); </p><p>  STUDENT *sort(STUDENT *h); &

75、lt;/p><p>  void total(STUDENT *h); </p><p>  int menu_select(); </p><p><b>  main()</b></p><p><b>  {</b></p><p><

76、;b>  int i;</b></p><p>  STUDENT *head; </p><p>  head=init(); </p><p>  clrscr(); </p><p>  for(;;) </p><p><b

77、>  {</b></p><p>  switch(menu_select()) </p><p>  case 0:head=init();break; </p><p>  case 1:head=create();break; </p><p>  case 2:head=delete(head);break;

78、 </p><p>  case 3:print(head);break; </p><p>  case 4:search(head);break;</p><p>  case 5:computer(head);break; </p><p>  case 6:head=insert(head); break; </p>

79、;<p>  case 7:copy();break; </p><p>  case 8:head=sort(head);break; </p><p>  case 9:total(head);break; </p><p>  case 10:exit(0); </p><p><b> 

80、 }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  menu_select()</p><p><b>  {</b></p><p>  char *menu[]={"

81、***************MENU***************", </p><p>  " 0. init list", </p><p>  " 1. Enter list", </p><p>  " 2. Delete a record from list", </

82、p><p>  " 3. print list ", </p><p>  " 4. Search record on name", </p><p>  " 5. compute the score", </p><p>  " 6. insert rec

83、ord to list ", </p><p>  " 7. copy the file to new file", /*復制文件*/</p><p>  " 8. sort to make new file", /*排序*/</p><p>  " 9. total on nomber&quo

84、t;, /*分類合計*/</p><p>  " 10. Quit"}; /*退出*/</p><p>  char s[3]; </p><p>  int c,i; </p><p>  gotoxy(1,25); </p><

85、p>  printf("press any key enter menu......\n"); </p><p>  getch(); </p><p>  clrscr(); </p><p>  gotoxy(1,1); <

86、/p><p>  textcolor(BLUE); </p><p>  textbackground(WHITE); </p><p>  gotoxy(10,2); </p><p>  putch(0xc9); </p><p>  for(i=1;i<44;i++)<

87、;/p><p>  putch(0xcd); </p><p>  putch(0xbb); </p><p>  for(i=3;i<20;i++)</p><p><b>  {</b></p><p>  gotoxy(10,i);putch(0xba); &l

88、t;/p><p>  gotoxy(54,i);putch(0xba);</p><p>  } /*輸出右垂直線*/</p><p>  gotoxy(10,20);putch(0xc8); </p><p>  for(i=1;i<44;i++)</p><p>  putch(0xcd); &l

89、t;/p><p>  putch(0xbc); </p><p>  window(11,3,53,19); </p><p>  clrscr(); </p><p>  for(i=0;i<16;i++) </p><p><b>

90、;  {</b></p><p>  gotoxy(10,i+1);</p><p>  cprintf("%s",menu[i]);</p><p><b>  }</b></p><p>  textbackground(GREEN); </p><p>  

91、window(1,1,80,25); </p><p>  gotoxy(10,21); </p><p><b>  do{</b></p><p>  printf("\n Enter you choice(0~10):"); </p><p>  scanf(&q

92、uot;%s",s); </p><p>  c=atoi(s); </p><p>  }while(c<0||c>10); </p><p>  return c; </p><p><b>  }</b></p>

93、<p>  STUDENT *init()</p><p><b>  {</b></p><p>  return NULL;</p><p><b>  }</b></p><p>  STUDENT *create()</p><p><b> 

94、 {</b></p><p>  int i; int s;</p><p>  STUDENT *h=NULL,*info; </p><p><b>  for(;;)</b></p><p><b>  {</b></p><p>  info=(STUD

95、ENT *)malloc(sizeof(STUDENT)); </p><p>  if(!info) </p><p><b>  {</b></p><p>  printf("\nout of memory"); </p><p>  return NULL; <

96、/p><p><b>  }</b></p><p>  inputs("enter no:",info->no,11); </p><p>  if(info->no[0]=='!') break; </p><p>  inputs("enter stu

97、dents' name:",info->name,20);</p><p>  printf("please input %d score \n",N); </p><p>  s=0; </p><p>  for(i=0;i<N;i++) {</p><p&

98、gt;<b>  do{</b></p><p>  printf("score%d:",i+1); </p><p>  scanf("%d",&info->score[i]); </p><p>  if(info->score[i]>100||info->

99、score[i]<0) </p><p>  printf("Data is bad ,repeat input\n"); </p><p>  }while(info->score[i]>100||info->score[i]<0);</p><p>  s=s+info->score[i]; <

100、/p><p><b>  }</b></p><p>  info->sum=s; </p><p>  info->average=(float)s/N; </p><p>  info->order=0; </p><p>  info->next=h;

101、</p><p>  h=info; </p><p><b>  }</b></p><p>  return(h); </p><p><b>  }</b></p><p>  inputs(char *prompt, char *s, int count)&l

102、t;/p><p><b>  {</b></p><p>  char p[255];</p><p><b>  do{</b></p><p>  printf(prompt); </p><p>  scanf("%s",p); </p>

103、<p>  if(strlen(p)>count)printf("\n too long! \n"); </p><p>  }while(strlen(p)>count);</p><p>  strcpy(s,p); </p><p><b>  }</b></p><p&g

104、t;  void print(STUDENT *h)</p><p><b>  {</b></p><p>  int i=0; </p><p>  STUDENT *p; </p><p>  clrscr(); </p><p><b>  p=h; &l

105、t;/b></p><p>  printf("\n\n\n****************************STUDENT********************************\n");</p><p>  printf("|Rec|No | Name | Sc1| Sc2| Sc3| Sum |

106、 Ave |Order|\n");</p><p>  printf("|---|----------|---------------|----|----|----|--------|-------|-----|\n");</p><p>  while(p!=NULL)</p><p><b>  {</b>&

107、lt;/p><p><b>  i++;</b></p><p>  printf("|%3d |%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", i, p->no,p->name,p->score[0],p->score[1],</p><p>  p

108、->score[2],p->sum,p->average,p->order);</p><p>  p=p->next;</p><p><b>  }</b></p><p>  printf("**********************************end*****************

109、****************\n");</p><p><b>  }</b></p><p>  STUDENT *delete(STUDENT *h)</p><p><b>  {</b></p><p>  STUDENT *p,*q; </p><p&g

110、t;  char s[11]; </p><p>  clrscr(); </p><p>  printf("please deleted no\n"); </p><p>  scanf("%s",s); </p><p>  q=p=h; </p>

111、<p>  while(strcmp(p->no,s)&&p!=NULL) </p><p><b>  {</b></p><p>  q=p; </p><p>  p=p->next; </p><p><b>  }</b><

112、;/p><p>  if(p==NULL) </p><p>  printf("\nlist no %s student\n",s);</p><p>  else </p><p><b>  {</b></p><p>  printf("*****

113、************************have found***************************\n");</p><p>  printf("|No | Name | Sc1| Sc2| Sc3| Sum | Ave |Order|\n");</p><p>  printf("|

114、----------|---------------|----|----|----|--------|-------|-----|\n");</p><p>  printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", p->no,</p><p>  p->name,p->sco

115、re[0],p->score[1],p->score[2],p->sum,</p><p>  p->average,p->order);</p><p>  printf("********************************end*******************************\n");</p>

116、<p>  getch(); </p><p>  if(p==h) </p><p>  h=p->next; </p><p><b>  else</b></p><p>  q->next=p->next; </p><p>  free(

117、p); </p><p>  printf("\n have deleted No %s student\n",s);</p><p>  printf("Don't forget save\n"); </p><p><b>  }</b></p><p&g

118、t;  return(h); </p><p><b>  }</b></p><p>  void search(STUDENT *h)</p><p><b>  {</b></p><p>  STUDENT *p; </p><p>  char s[1

119、5]; </p><p>  clrscr(); </p><p>  printf("Please enter students' name for search\n");</p><p>  scanf("%s",s); </p><p><b>  p=h; &

120、lt;/b></p><p>  while(strcmp(p->name,s)&&p!=NULL) </p><p>  p=p->next; </p><p>  if(p==NULL) </p><p>  printf("\nlist no %s student\n&q

121、uot;,s); </p><p>  else </p><p><b>  {</b></p><p>  printf("\n\n*****************************havefound***************************\n");</p>&l

122、t;p>  printf("|No | Name | Sc1| Sc2| Sc3| Sum | Ave |Order|\n");</p><p>  printf("|----------|---------------|----|----|----|--------|-------|-----|\n");</p>

123、<p>  printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |\n", p->no,</p><p>  p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);</p>

124、<p>  printf("********************************end*******************************\n");</p><p><b>  }</b></p><p><b>  }</b></p><p>  STUDENT *i

125、nsert(STUDENT *h)</p><p><b>  {</b></p><p>  STUDENT *p,*q,*info; </p><p>  char s[11]; </p><p><b>  int s1,i;</b></p><p>  printf(

126、"please enter location before the no\n");</p><p>  scanf("%s",s); </p><p>  printf("\nplease new record\n"); </p><p>  info=(STUDENT *)malloc(siz

127、eof(STUDENT)); </p><p><b>  if(!info)</b></p><p><b>  {</b></p><p>  printf("\nout of memory"); </p><p>  return NULL; &

128、lt;/p><p><b>  }</b></p><p>  inputs("enter no:",info->no,11); </p><p>  inputs("enter name:",info->name,15); </p><p>  printf("

129、please input %d score \n",N); </p><p><b>  s1=0; </b></p><p>  for(i=0;i<N;i++) </p><p><b>  {</b></p><p>  do{ </p>&

130、lt;p>  printf("score%d:",i+1);</p><p>  scanf("%d",&info->score[i]);</p><p>  if(info->score[i]>100||info->score[i]<0)</p><p>  printf(&quo

131、t;bad data,repeat input\n");</p><p>  }while(info->score[i]>100||info->score[i]<0);</p><p>  s1=s1+info->score[i]; </p><p><b>  }</b></p>&l

132、t;p>  info->sum=s1; </p><p>  info->average=(float)s1/N; </p><p>  info->order=0; </p><p>  info->next=NULL; </p><p>  p=h;

133、 </p><p>  q=h; </p><p>  while(strcmp(p->no,s)&&p!=NULL) </p><p><b>  {</b></p><p>  q=p; </p><p>  p

134、=p->next; </p><p><b>  }</b></p><p>  if(p==NULL) </p><p>  if(p==h) </p><p><b>  h=info; </b></p><p><b&

135、gt;  else</b></p><p>  q->next=info; </p><p><b>  else</b></p><p>  if(p==h) </p><p><b>  {</b></p><p>  info->next=

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論