版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 《C語(yǔ)言程序設(shè)計(jì)》課程設(shè)計(jì)報(bào)告</p><p> 專 業(yè): 電子信息工程 </p><p> 班 級(jí): </p><p> 姓 名: </p><p> 指導(dǎo)教師: </p><p>
2、 2011年12月28日</p><p> 目 錄</p><p> 1.課程設(shè)計(jì)目的…………………………………………………2 </p><p> 2.課程設(shè)計(jì)題目描述和要求……………………………………2 </p><p> 3.課程設(shè)計(jì)報(bào)告內(nèi)容 ……………………………………………3</p><p&g
3、t; 3.1 所涉及知識(shí)點(diǎn) ……………………………………………3 </p><p> 3.2課程設(shè)計(jì)的思路以及流程圖 ……………………………3 </p><p> 3.3個(gè)人負(fù)責(zé)程序說(shuō)明 ………………………………………4</p><p> 3.4課程設(shè)計(jì)中遇到的問(wèn)題以及解決方法 …………………11 </p><p> 4.個(gè)人設(shè)計(jì)總
4、結(jié)…………………………………………………11 </p><p> 5.參考書(shū)目………………………………………………………11 </p><p> 6.附錄源程序代碼………………………………………………11</p><p> 《C語(yǔ)言程序設(shè)計(jì)》課程設(shè)計(jì)任務(wù)書(shū)</p><p><b> 1、課程設(shè)計(jì)目的</b><
5、;/p><p> (1)、熟練掌握C語(yǔ)言課程中所學(xué)的理論知識(shí);</p><p> (2)、通過(guò)綜合C語(yǔ)言的基本知識(shí)來(lái)解決實(shí)際問(wèn)題;</p><p> ?。?)、加強(qiáng)分析和解決問(wèn)題的能力。</p><p> 2、課程設(shè)計(jì)題目描述和要求</p><p> (1)課程設(shè)計(jì)題目:成績(jī)信息管理系統(tǒng)。</p>&
6、lt;p> ?。?)課程設(shè)計(jì)要求:</p><p> a,設(shè)計(jì)包含N個(gè)學(xué)生的數(shù)據(jù)信息的學(xué)生成績(jī)管理系統(tǒng),包括以下信息: </p><p> 學(xué)號(hào)、 姓名(拼音)、三門(mén)課程成績(jī)(高數(shù)、英語(yǔ)、計(jì)算機(jī)) </p><p> b,系統(tǒng)功能包括: </p><p> 1、學(xué)生信息的錄入(增加數(shù)據(jù))。用數(shù)組數(shù)據(jù)類型賦初值的方法或從鍵盤(pán)輸入的
7、方法把學(xué)生的數(shù)據(jù)送到各個(gè)數(shù)組中(注意要是合法數(shù)據(jù)),然后把它們輸出顯示。</p><p> 2、學(xué)生信息的刪除(刪除數(shù)據(jù))。任意輸入一位學(xué)生的學(xué)號(hào),將它所有的信息從數(shù)組中刪除。</p><p> 3、學(xué)生信息的瀏覽(查找數(shù)據(jù))。任意輸入一位學(xué)生的學(xué)號(hào),打印出他的所有數(shù)據(jù)。要求能多次查找。</p><p> 4、學(xué)生信息的修改(修改數(shù)據(jù))。任意輸入一位學(xué)生的學(xué)號(hào)
8、,打印出所有相關(guān)信息后,可對(duì)某一項(xiàng)信息進(jìn)行修改并保存。</p><p> 5、學(xué)生信息的計(jì)算并排序。計(jì)算每個(gè)學(xué)生三門(mén)課程的總分(sum,整型)及平均分(aver,單精度,輸出一位小數(shù)),將包括所有數(shù)據(jù)的數(shù)組元素按總分從大到小的順序排序打印出來(lái)。</p><p> 6、程序編譯成員及模塊分配</p><p> 主函數(shù)的設(shè)計(jì)—------------</p&
9、gt;<p> 信息錄入模塊的設(shè)計(jì)--------</p><p> 刪除模塊的設(shè)計(jì)------------</p><p> 修改模塊的設(shè)計(jì)------------</p><p> 瀏覽模塊的設(shè)計(jì)------------</p><p> 計(jì)算與排序模塊的設(shè)計(jì)------</p><p>
10、 3、課程設(shè)計(jì)報(bào)告內(nèi)容</p><p> 3.1. 所涉及知識(shí)點(diǎn):</p><p> 指針的定義與引用;函數(shù)的定義與調(diào)用;局部變量和全局變量大的定義; for循環(huán)語(yǔ)句的使用;if語(yǔ)句的使用;break語(yǔ)句的使用;格式輸入與輸出;比較法排序;函數(shù)的定義;數(shù)組作為函數(shù)參數(shù)。</p><p> 3.2課程設(shè)計(jì)的思路以及流程圖</p><p>
11、<b> 一:課程設(shè)計(jì)思路</b></p><p> 主程序?yàn)閙ain(),子程序有個(gè)分別為Add(l),Qur(l), Modify(l), Insert(l), Tongji(l), Sort(l), Save(l)。分別可以實(shí)現(xiàn)錄入學(xué)生信息,刪除學(xué)生信息,瀏覽學(xué)生信息,修改學(xué)生信息,對(duì)信息學(xué)生排序,以及對(duì)學(xué)生信息保存。</p><p> 二、課程設(shè)計(jì)思路及
12、結(jié)構(gòu)圖</p><p> 根據(jù)題目的要求,需要一個(gè)主程序main()和若干子程序,其如結(jié)構(gòu)圖下:</p><p> 1、初始化函數(shù) STUDENT *init()</p><p> 這是一個(gè)無(wú)參函數(shù),里面只有一個(gè)語(yǔ)句,它的作用是使鏈表初始化,使head的值為NULL。比如:沒(méi)有這個(gè)函數(shù)的話,在你沒(méi)有輸入任何數(shù)據(jù)的情況下,去執(zhí)行顯示功能的時(shí)候會(huì)顯示一
13、些亂碼!</p><p> 2、菜單選擇函數(shù) int menu_select();</p><p> 這是一個(gè)無(wú)參函數(shù),主要實(shí)現(xiàn)“功能選擇”的界面,在這個(gè)界面里有顯示系統(tǒng)的九大功能,根據(jù)每個(gè)功能前面的序號(hào)進(jìn)行選擇,中間還顯示系統(tǒng)當(dāng)前的時(shí)間。等執(zhí)行完每一個(gè)函數(shù)功能后,按任一鍵回到主界面也要通過(guò)這個(gè)函數(shù)來(lái)實(shí)現(xiàn)!</p><p> 3、輸入記錄函數(shù) STUDENT
14、*create()</p><p> 這是一個(gè)無(wú)參函數(shù),用來(lái)執(zhí)行第學(xué)生成績(jī)記錄的輸入,當(dāng)學(xué)生為0時(shí)停止輸入,函數(shù)結(jié)束后,帶回一個(gè)指向鏈表頭的指針head。</p><p> 算法:先聲明一個(gè)首節(jié)點(diǎn)head,并將head->next設(shè)為NULL。每輸入一個(gè)數(shù)據(jù)就聲明一個(gè)新節(jié)點(diǎn)p,把p->next設(shè)為NULL,并且鏈接到之前列表的尾端。</p><p>
15、<b> N-S流程圖如下:</b></p><p> 4、顯示記錄函數(shù) void print(STUDENT *head)</p><p> 這是一個(gè)不返回值的有參函數(shù),形參為“鏈表頭的指針”,負(fù)責(zé)對(duì)全部學(xué)生成績(jī)記錄的輸出,不足之處就是不能對(duì)學(xué)生成績(jī)進(jìn)行分頁(yè)顯示。</p><p> 算法:先將p結(jié)點(diǎn)的指針指向第一個(gè)結(jié)點(diǎn),將p結(jié)點(diǎn)(即第
16、一個(gè)結(jié)點(diǎn))的數(shù)據(jù)輸出。然后再將p結(jié)點(diǎn)的指針指向p指針的的指針(即下一結(jié)點(diǎn)),將p結(jié)點(diǎn)(即第一結(jié)點(diǎn))的數(shù)據(jù)輸出。重復(fù)執(zhí)行此步聚直到p指針指向NULL為止。</p><p><b> N-S流程圖如下:</b></p><p> 5、查找記錄函數(shù) void search(STUDENT *head)</p><p> 這是一個(gè)不返回值的有參函
17、數(shù),形參為“鏈表頭的指針”,實(shí)現(xiàn)按學(xué)號(hào)對(duì)某個(gè)學(xué)生進(jìn)行查找,并顯示所查找到的記錄。</p><p> 算法:采用線性查找法往下一個(gè)節(jié)點(diǎn)查找。輸入所要查找的學(xué)生的學(xué)號(hào)s,設(shè)一個(gè)指針變量p,先指向第一個(gè)結(jié)點(diǎn),當(dāng)strcmp(p->name,s) && p != NULL時(shí),使p后移一個(gè)結(jié)點(diǎn),如果p!=NULL,輸出p所指的結(jié)點(diǎn)。</p><p><b> N-
18、S流程圖如下:</b></p><p><b> 源程序如下:</b></p><p> /*************************************************************</p><p> 作用:用于定位鏈表中符合要求的節(jié)點(diǎn),并返回指向該節(jié)點(diǎn)的指針</p><p&
19、gt; 參數(shù):findmess[]保存要查找的具體內(nèi)容; nameornum[]保存按什么查找;</p><p><b> 在單鏈表l中查找;</b></p><p> **************************************************************/</p><p> Node* Locat
20、e(Link l,char findmess[],char nameornum[])</p><p><b> {</b></p><p><b> Node *r;</b></p><p> if(strcmp(nameornum,"num")==0) /*按學(xué)號(hào)查詢*/</p>
21、<p><b> {</b></p><p> r=l->next;</p><p><b> while(r)</b></p><p><b> {</b></p><p> if(strcmp(r->data.num,findmess)==0
22、) /*若找到findmess值的學(xué)號(hào)*/</p><p><b> return r;</b></p><p> r=r->next;</p><p><b> }</b></p><p><b> }</b></p><p> els
23、e if(strcmp(nameornum,"name")==0) /*按姓名查詢*/</p><p><b> {</b></p><p> r=l->next;</p><p><b> while(r)</b></p><p><b> {</
24、b></p><p> if(strcmp(r->data.name,findmess)==0) /*若找到findmess值的學(xué)生姓名*/</p><p><b> return r;</b></p><p> r=r->next;</p><p><b> }</b&g
25、t;</p><p><b> }</b></p><p> return 0; /*若未找到,返回一個(gè)空指針*/</p><p><b> }</b></p><p> /*輸入字符串,并進(jìn)行長(zhǎng)度驗(yàn)證(長(zhǎng)度<lens)*/</p><p> void str
26、inginput(char *t,int lens,char *notice)</p><p><b> {</b></p><p> char n[255];</p><p><b> do{</b></p><p> printf(notice); /*顯示提示信息*/</p>
27、;<p> scanf("%s",n); /*輸入字符串*/</p><p> if(strlen(n)>lens)printf("\n 超出要求范圍! \n"); /*進(jìn)行長(zhǎng)度校驗(yàn),超過(guò)lens值重新輸入*/</p><p> }while(strlen(n)>lens);</p><p>
28、 strcpy(t,n); /*將輸入的字符串拷貝到字符串t中*/</p><p><b> }</b></p><p> /*輸入分?jǐn)?shù),0<=分?jǐn)?shù)<=100)*/</p><p> int numberinput(char *notice)</p><p><b> {</b>
29、</p><p><b> int t=0;</b></p><p><b> do{</b></p><p> printf(notice); /*顯示提示信息*/</p><p> scanf("%d",&t); /*輸入分?jǐn)?shù)*/</p><
30、;p> if(t>100 || t<0) printf("\n 成績(jī)范圍[0,100]! \n"); /*進(jìn)行分?jǐn)?shù)校驗(yàn)*/</p><p> }while(t>100 || t<0);</p><p><b> return t;</b></p><p><b> }</
31、b></p><p> 6、刪除記錄函數(shù) STUDENT *delete(STUDENT *head)</p><p> 這是一個(gè)有參函數(shù),形參為“鏈表頭的指針”,先輸入要?jiǎng)h除的學(xué)生記錄的學(xué)號(hào),找到后顯示該學(xué)生信息,等確認(rèn)后便可按“Y”進(jìn)行刪除。</p><p> 算法:從p指向的第一個(gè)結(jié)點(diǎn)開(kāi)始,檢查該結(jié)點(diǎn)中的num值是否等于輸入的要求刪除的那個(gè)學(xué)號(hào)。如
32、果相等就將該結(jié)點(diǎn)刪除,如不相等,就將p后移一個(gè)結(jié)點(diǎn),再如此進(jìn)行下去,直到遇到表尾為止。</p><p><b> N-S流程圖如下:</b></p><p> 7、排序函數(shù) STUDENT *sort(STUDENT *head)</p><p> 這是一個(gè)有參函數(shù),形參為“鏈表頭的指針”,按學(xué)生成績(jī)的平均分高低進(jìn)行排序,還可以顯示名次。
33、</p><p><b> N-S流程圖:</b></p><p> 8、插入函數(shù) STUDENT *insert(STUDENT *head,STUDENT *new)</p><p> 這是一個(gè)有參函數(shù),形參有兩個(gè),一個(gè)是“鏈表頭的指針”,一個(gè)是“待插入指針”,按照原來(lái)成績(jī)平均分的高低進(jìn)行插入,插入后會(huì)重新進(jìn)行排序,并返回。</
34、p><p> 算法:先將學(xué)生的成績(jī)按平均分由高分到低分進(jìn)行排序,再插入一個(gè)新生的結(jié)點(diǎn),要求按平均分的高低順序插入。先用指針變量p0指向待插入的結(jié)點(diǎn),p1指向第一個(gè)結(jié)點(diǎn)。如果p0->average<p1->average,則待插入的結(jié)點(diǎn)不應(yīng)插在p1所指的結(jié)點(diǎn)之前。此時(shí)將p1后移,并使p2指向剛才p1所指的結(jié)點(diǎn)。重復(fù)以上的步驟,直到p0->average>=p1->average為止
35、。這時(shí)將p0指向的結(jié)點(diǎn)插到p1所指結(jié)點(diǎn)之前。但是如果p1所指的已是表尾結(jié)點(diǎn),則p1就不應(yīng)后移了。如果p0->average比所有結(jié)點(diǎn)的average都小,則應(yīng)將p0所指的結(jié)點(diǎn)插到鏈表末尾。如果插入的位置既不在第一個(gè)結(jié)點(diǎn)之前,又不在表尾結(jié)點(diǎn)之后,則將p0的值賦給p2->,使p2->next指向待插入的結(jié)點(diǎn),然后將p1的值賦給p0->next,使得p0->next指向p1指向的變量。如果插入位置為第一個(gè)結(jié)點(diǎn)之前
36、,則將p0賦給head,將p1賦給p0->next。如果要插到表尾之后,應(yīng)將p0賦給p1->next,NULL賦給p0->next。最后再調(diào)用排序的函數(shù),將學(xué)生成績(jī)重新排序.</p><p><b> N-S流程圖如下:</b></p><p> 9、保存數(shù)據(jù)到文件函數(shù) void save(STUDENT *head)</p>&l
37、t;p> 這是一個(gè)不返回值的有參函數(shù),形參為“鏈表頭的指針”,可以把學(xué)生記錄保存在電腦上由自己任意命名的二進(jìn)制文件。</p><p><b> N-S流程圖如下:</b></p><p> 10、從文件讀數(shù)據(jù)函數(shù) STUDENT *load()</p><p> 這是一個(gè)不返回值的有參函數(shù),形參為“鏈表頭的指針”,根據(jù)輸入的文件地
38、址進(jìn)行讀取。</p><p><b> N-S流程圖如下:</b></p><p> 3.3 個(gè)人負(fù)責(zé)程序說(shuō)明</p><p> 學(xué)生信息的瀏覽(查找數(shù)據(jù))。任意輸入一位學(xué)生的學(xué)號(hào),打印出他的所有數(shù)據(jù)。要求能多次查找。</p><p> 3.4課程設(shè)計(jì)中遇到的問(wèn)題以及解決方法</p><p&g
39、t; ?。?)剛開(kāi)始沒(méi)有那個(gè)初始化函數(shù),程序運(yùn)行后,沒(méi)有輸入任何數(shù)據(jù)就試得去執(zhí)行顯示功能,結(jié)果顯示的是一些亂碼!加入初始化函數(shù)后,這種現(xiàn)象也隨之消失。</p><p> ?。?)剛開(kāi)始時(shí),先把成績(jī)按平均分排序,再插入一個(gè)學(xué)生的成績(jī),執(zhí)行顯示功能,雖然插入的學(xué)生的成績(jī)能正常插入,但該學(xué)生的名次為0。后來(lái),在插入成績(jī)之后,調(diào)用排序函數(shù),把所有成績(jī)重新排序一次。</p><p> (3)在輸入
40、函數(shù)中設(shè)了一個(gè)無(wú)限循環(huán),可以輸入無(wú)數(shù)個(gè)學(xué)生的成績(jī)信息,當(dāng)學(xué)號(hào)為0的時(shí)候則停止輸入。</p><p> ?。?)輸入太多個(gè)學(xué)生的成績(jī)時(shí),屏幕顯示不能控制為一頁(yè)一頁(yè)顯示,所以為了方便起見(jiàn),不要輸入太多記錄,十七左右為最佳。</p><p> ?。?)在沒(méi)有輸入任何信息的情況下,去執(zhí)行排序功能,最后顯示有一個(gè)記錄,學(xué)號(hào)、姓名為空白,成績(jī)都為0,名次為1。</p><p>
41、 (7)在輸入選項(xiàng)時(shí)不能輸入字母,否則會(huì)死循環(huán),建議不要亂輸字母。</p><p><b> 4、個(gè)人設(shè)計(jì)總結(jié)</b></p><p> C語(yǔ)言課程設(shè)計(jì),感覺(jué)自己收獲了不少,通過(guò)這個(gè)課程設(shè)計(jì)提高了對(duì)編程語(yǔ)言的興趣,同時(shí)加深了對(duì)C語(yǔ)言的理解!</p><p> 本來(lái)按老師建議的是用結(jié)構(gòu)體數(shù)組,但是由于沒(méi)有學(xué)習(xí)結(jié)構(gòu)體數(shù)組,而自己自學(xué)起來(lái)我們
42、個(gè)人感覺(jué)指針更簡(jiǎn)單一些,所以采用了指針的方法。</p><p> 鏈表本來(lái)上課是沒(méi)有學(xué)的,但這個(gè)課程設(shè)計(jì)里面主要都是用鏈表,因?yàn)橐_(dá)到這樣的功能,使用鏈表相當(dāng)方便,但不容易理解,所以在這方面我很了很多的時(shí)間看課本和參考課外書(shū),使C語(yǔ)言的知識(shí)強(qiáng)化了不少。</p><p> 在做課程設(shè)計(jì)的過(guò)程中,發(fā)現(xiàn)了平時(shí)很多沒(méi)有注意到的問(wèn)題,例如:返回值函數(shù)和不返回值函數(shù)兩者在主函數(shù)中的調(diào)用是不同的等等
43、。</p><p> 這次課程設(shè)計(jì)雖然花了我不少時(shí)間,但正是這些時(shí)間,讓我見(jiàn)識(shí)到了C語(yǔ)言的重要性。</p><p><b> 5、參考書(shū)目</b></p><p> Schildt H著,戴健鵬譯,C語(yǔ)言大全(第二版),電子工業(yè)出版社,京,1994年</p><p> 譚浩強(qiáng),《c程序設(shè)計(jì)教程》,清華大學(xué)出版社,
44、北京,2005年</p><p> 譚浩強(qiáng),《c程序設(shè)計(jì)題解與上機(jī)指導(dǎo)》,清華大學(xué)出版社,北京,2006年</p><p><b> 6、附錄源程序代碼</b></p><p> #include "stdio.h" /*標(biāo)準(zhǔn)輸入輸出函數(shù)庫(kù)*/</p><p> #include &quo
45、t;stdlib.h" /*標(biāo)準(zhǔn)函數(shù)庫(kù)*/</p><p> #include "string.h" /*字符串函數(shù)庫(kù)*/</p><p> #include "conio.h" /*屏幕操作函數(shù)庫(kù)*/</p><p> #define HEADER1 " ------------------
46、----------學(xué)生成績(jī)表---------------------------------- \n"</p><p> #define HEADER2 " | 學(xué)號(hào) | 姓名 |計(jì)算機(jī)|數(shù)學(xué)|英語(yǔ) | 總分 | 平均分 |名次 | \n"</p><p> #define HEADER3 "
47、 |---------------|-------------|-----|-----|-----|--------|-------|-----| "</p><p> #define FORMAT " | %-10s |%-14s|%4d| %4d| %4d| %4d | %.2f |%4d |\n"</p><p> #defin
48、e DATA p->data.num,p->data.name,p->data.egrade,p->data.mgrade,p->data.cgrade,p->data.total,p->data.ave,p->data.mingci</p><p> #define END " ---------------------------
49、------------------------------------------ \n"</p><p> int saveflag=0; /*是否需要存盤(pán)的標(biāo)志變量*/</p><p> /*定義與學(xué)生有關(guān)的數(shù)據(jù)結(jié)構(gòu)*/</p><p> typedef struct student /*標(biāo)記為student*/</p>
50、<p><b> {</b></p><p> char num[10]; /*學(xué)號(hào)*/</p><p> char name[15]; /*姓名*/</p><p> int cgrade; /*計(jì)算機(jī)成績(jī)*/</p><p> int mgrade; /*數(shù)學(xué)成績(jī)*/<
51、/p><p> int egrade; /*英語(yǔ)成績(jī)*/</p><p> int total; /*總分*/</p><p> float ave; /*平均分*/</p><p> int mingci; /*名次*/</p><p><b> };</b&
52、gt;</p><p> /*定義每條記錄或結(jié)點(diǎn)的數(shù)據(jù)結(jié)構(gòu),標(biāo)記為:node*/</p><p> typedef struct node</p><p><b> {</b></p><p> struct student data; /*數(shù)據(jù)域*/</p><p> struct n
53、ode *next; /*指針域*/</p><p> }Node,*Link; /*Node為node類型的結(jié)構(gòu)變量,*Link為node類型的指針變量*/</p><p> void menu() /*主菜單*/</p><p><b> {</b></p><p> system("cl
54、s"); /*調(diào)用DOS命令,清屏.與clrscr()功能相同*/</p><p> cprintf(" 學(xué)生成績(jī)管理系統(tǒng) \n");</p><p> cprintf(" *************************菜單*********************************
55、\n");</p><p> cprintf(" * 1 輸入記錄 * 2 刪除記錄 *\n");</p><p> cprintf(" * 3 查詢記錄 * 4 修改記錄 *\n"
56、);</p><p> cprintf(" * 5 添加記錄 * 6 統(tǒng)計(jì)打印記錄 *\n");</p><p> cprintf(" * 7 排序打印記錄 * 8 保存記錄 *\n");</p>
57、<p> cprintf(" * 0 退出系統(tǒng) *\n");</p><p> cprintf(" **************************************************************\n");</p
58、><p> /*cprintf()送格式化輸出至文本窗口屏幕中*/</p><p><b> }</b></p><p> void printheader() /*格式化輸出表頭*/</p><p><b> {</b></p><p> printf(HEADER1
59、);</p><p> printf(HEADER2);</p><p> printf(HEADER3);</p><p><b> }</b></p><p> void printdata(Node *pp) /*格式化輸出表中數(shù)據(jù)*/</p><p><b> {<
60、;/b></p><p><b> Node* p;</b></p><p><b> p=pp;</b></p><p> printf(FORMAT,DATA);</p><p><b> }</b></p><p> void Wr
61、ong() /*輸出按鍵錯(cuò)誤信息*/</p><p><b> {</b></p><p> printf("\n\n\n\n\n***********錯(cuò)誤:輸入有誤! 按任意鍵繼續(xù)**********\n");</p><p> getchar();</p><p><b> }&
62、lt;/b></p><p> void Nofind() /*輸出未查找此學(xué)生的信息*/</p><p><b> {</b></p><p> printf("\n=====>未找到該學(xué)生!\n");</p><p><b> }</b></p>
63、;<p> void Disp(Link l) /*顯示單鏈表l中存儲(chǔ)的學(xué)生記錄,內(nèi)容為student結(jié)構(gòu)中定義的內(nèi)容*/</p><p><b> {</b></p><p><b> Node *p;</b></p><p> p=l->next; /*l存儲(chǔ)的是單鏈表中頭結(jié)點(diǎn)的指針,該頭結(jié)
64、點(diǎn)沒(méi)有存儲(chǔ)學(xué)生信息,指針域指向的后繼結(jié)點(diǎn)才有學(xué)生信息*/</p><p> if(!p) /*p==NULL,NUll在stdlib中定義為0*/</p><p><b> {</b></p><p> printf("\n=====>沒(méi)有學(xué)生記錄!\n");</p><p> getc
65、har();</p><p><b> return;</b></p><p><b> }</b></p><p> printf("\n\n");</p><p> printheader(); /*輸出表格頭部*/</p><p> whi
66、le(p) /*逐條輸出鏈表中存儲(chǔ)的學(xué)生信息*/</p><p><b> {</b></p><p> printdata(p);</p><p> p=p->next; /*移動(dòng)直下一個(gè)結(jié)點(diǎn)*/</p><p> printf(HEADER3);</p><p><b
67、> }</b></p><p> getchar();</p><p><b> }</b></p><p> /*************************************************************</p><p> 作用:用于定位鏈表中符合要求的節(jié)點(diǎn),并
68、返回指向該節(jié)點(diǎn)的指針</p><p> 參數(shù):findmess[]保存要查找的具體內(nèi)容; nameornum[]保存按什么查找;</p><p><b> 在單鏈表l中查找;</b></p><p> **************************************************************/</p
69、><p> Node* Locate(Link l,char findmess[],char nameornum[])</p><p><b> {</b></p><p><b> Node *r;</b></p><p> if(strcmp(nameornum,"num"
70、;)==0) /*按學(xué)號(hào)查詢*/</p><p><b> {</b></p><p> r=l->next;</p><p><b> while(r)</b></p><p><b> {</b></p><p> if(strcmp
71、(r->data.num,findmess)==0) /*若找到findmess值的學(xué)號(hào)*/</p><p><b> return r;</b></p><p> r=r->next;</p><p><b> }</b></p><p><b> }</b&g
72、t;</p><p> else if(strcmp(nameornum,"name")==0) /*按姓名查詢*/</p><p><b> {</b></p><p> r=l->next;</p><p><b> while(r)</b></p>
73、<p><b> {</b></p><p> if(strcmp(r->data.name,findmess)==0) /*若找到findmess值的學(xué)生姓名*/</p><p><b> return r;</b></p><p> r=r->next;</p>&
74、lt;p><b> }</b></p><p><b> }</b></p><p> return 0; /*若未找到,返回一個(gè)空指針*/</p><p><b> }</b></p><p> /*輸入字符串,并進(jìn)行長(zhǎng)度驗(yàn)證(長(zhǎng)度<lens)*/<
75、;/p><p> void stringinput(char *t,int lens,char *notice)</p><p><b> {</b></p><p> char n[255];</p><p><b> do{</b></p><p> printf(
76、notice); /*顯示提示信息*/</p><p> scanf("%s",n); /*輸入字符串*/</p><p> if(strlen(n)>lens)printf("\n 超出要求范圍! \n"); /*進(jìn)行長(zhǎng)度校驗(yàn),超過(guò)lens值重新輸入*/</p><p> }while(strlen(n)>
77、lens);</p><p> strcpy(t,n); /*將輸入的字符串拷貝到字符串t中*/</p><p><b> }</b></p><p> /*輸入分?jǐn)?shù),0<=分?jǐn)?shù)<=100)*/</p><p> int numberinput(char *notice)</p><
78、;p><b> {</b></p><p><b> int t=0;</b></p><p><b> do{</b></p><p> printf(notice); /*顯示提示信息*/</p><p> scanf("%d",&
79、;t); /*輸入分?jǐn)?shù)*/</p><p> if(t>100 || t<0) printf("\n 成績(jī)范圍[0,100]! \n"); /*進(jìn)行分?jǐn)?shù)校驗(yàn)*/</p><p> }while(t>100 || t<0);</p><p><b> return t;</b></p>
80、<p><b> }</b></p><p> /*增加學(xué)生記錄*/</p><p> void Add(Link l)</p><p><b> {</b></p><p> Node *p,*r,*s; /*實(shí)現(xiàn)添加操作的臨時(shí)的結(jié)構(gòu)體指針變量*/</p>&
81、lt;p> char ch,flag=0,num[10];</p><p><b> r=l;</b></p><p> s=l->next;</p><p> system("cls");</p><p> Disp(l); /*先打印出已有的學(xué)生信息*/</p>
82、<p> while(r->next!=NULL)</p><p> r=r->next; /*將指針移至于鏈表最末尾,準(zhǔn)備添加記錄*/</p><p> while(1) /*一次可輸入多條記錄,直至輸入學(xué)號(hào)為0的記錄結(jié)點(diǎn)添加操作*/</p><p><b> {</b></p><p>
83、; while(1) /*輸入學(xué)號(hào),保證該學(xué)號(hào)沒(méi)有被使用,若輸入學(xué)號(hào)為0,則退出添加記錄操作*/</p><p><b> {</b></p><p> stringinput(num,10,"輸入學(xué)號(hào)(按'0'返回菜單):"); /*格式化輸入學(xué)號(hào)并檢驗(yàn)*/</p><p><b> fl
84、ag=0;</b></p><p> if(strcmp(num,"0")==0) /*輸入為0,則退出添加操作,返回主界面*/</p><p><b> {return;}</b></p><p> s=l->next;</p><p> while(s) /*查詢?cè)搶W(xué)號(hào)是
85、否已經(jīng)存在,若存在則要求重新輸入一個(gè)未被占用的學(xué)號(hào)*/</p><p> {if(strcmp(s->data.num,num)==0)</p><p><b> {</b></p><p><b> flag=1;</b></p><p><b> break;</b
86、></p><p><b> }</b></p><p> s=s->next;</p><p><b> }</b></p><p> if(flag==1) /*提示用戶是否重新輸入*/</p><p> { getchar();</p>
87、<p> printf("=====>學(xué)號(hào) %s 不存在,重新輸入?(y/n):",num);</p><p> scanf("%c",&ch);</p><p> if(ch=='y'||ch=='Y')</p><p><b> continue
88、;</b></p><p><b> else</b></p><p><b> return;</b></p><p><b> }</b></p><p><b> else</b></p><p><
89、b> {break;}</b></p><p><b> }</b></p><p> p=(Node *)malloc(sizeof(Node)); /*申請(qǐng)內(nèi)存空間*/</p><p><b> if(!p)</b></p><p><b> {</b
90、></p><p> printf("\n 分配失敗 "); /*如沒(méi)有申請(qǐng)到,打印提示信息*/</p><p> return ; /*返回主界面*/</p><p><b> }</b></p><p> strcpy(p->data.num,num);
91、 /*將字符串num拷貝到p->data.num中*/</p><p> stringinput(p->data.name,15,"Name:");</p><p> p->data.cgrade=numberinput("Computer Score[0-100]:"); /*輸入并檢驗(yàn)分?jǐn)?shù),分?jǐn)?shù)必須在0-100之間*/<
92、;/p><p> p->data.mgrade=numberinput("Math Score[0-100]:"); /*輸入并檢驗(yàn)分?jǐn)?shù),分?jǐn)?shù)必須在0-100之間*/</p><p> p->data.egrade=numberinput("English Score[0-100]:"); /*輸入并檢驗(yàn)分?jǐn)?shù),分?jǐn)?shù)必須在0-10
93、0之間*/</p><p> p->data.total=p->data.egrade+p->data.cgrade+p->data.mgrade; /*計(jì)算總分*/</p><p> p->data.ave=(float)(p->data.total/3); /*計(jì)算平均分*/</p><p> p->data.mi
94、ngci=0;</p><p> p->next=NULL; /*表明這是鏈表的尾部結(jié)點(diǎn)*/</p><p> r->next=p; /*將新建的結(jié)點(diǎn)加入鏈表尾部中*/</p><p><b> r=p;</b></p><p> saveflag=1;</p><p><
95、;b> }</b></p><p><b> return ;</b></p><p><b> }</b></p><p> void Qur(Link l) /*按學(xué)號(hào)或姓名,查詢學(xué)生記錄*/</p><p><b> {</b></p&g
96、t;<p> int select; /*1:按學(xué)號(hào)查,2:按姓名查,其他:返回主界面(菜單)*/</p><p> char searchinput[20]; /*保存用戶輸入的查詢內(nèi)容*/</p><p><b> Node *p;</b></p><p> if(!l->next) /*若鏈表為空*/</
97、p><p><b> {</b></p><p> system("cls");</p><p> printf("\n=====>沒(méi)有學(xué)生記錄!\n");</p><p> getchar();</p><p><b> return
98、;</b></p><p><b> }</b></p><p> system("cls");</p><p> printf("\n =====>1 按學(xué)號(hào)查詢 =====>2 按姓名查詢\n");</p><p> printf(&q
99、uot; 請(qǐng)選擇[1,2]:");</p><p> scanf("%d",&select);</p><p> if(select==1) /*按學(xué)號(hào)查詢*/</p><p><b> {</b></p><p> stringinput(searchinpu
100、t,10,"input the existing student number:");</p><p> p=Locate(l,searchinput,"num");/*在l中查找學(xué)號(hào)為searchinput值的節(jié)點(diǎn),并返回節(jié)點(diǎn)的指針*/</p><p> if(p) /*若p!=NULL*/</p><p><b&
101、gt; {</b></p><p> printheader();</p><p> printdata(p);</p><p> printf(END);</p><p> printf("按任意鍵返回");</p><p> getchar();</p>&
102、lt;p><b> }</b></p><p><b> else</b></p><p><b> Nofind();</b></p><p> getchar();</p><p><b> }</b></p><p
103、> else if(select==2) /*按姓名查詢*/</p><p><b> {</b></p><p> stringinput(searchinput,15,"input the existing student name:");</p><p> p=Locate(l,searchinput,&
104、quot;name");</p><p><b> if(p)</b></p><p><b> {</b></p><p> printheader();</p><p> printdata(p);</p><p> printf(END);</
105、p><p> printf("按任意鍵返回");</p><p> getchar();</p><p><b> }</b></p><p><b> else</b></p><p><b> Nofind();</b>&l
106、t;/p><p> getchar();</p><p><b> }</b></p><p><b> else</b></p><p><b> Wrong();</b></p><p> getchar();</p><p
107、><b> }</b></p><p> /*刪除學(xué)生記錄:先找到保存該學(xué)生記錄的節(jié)點(diǎn),然后刪除該節(jié)點(diǎn)*/</p><p> void Del(Link l)</p><p><b> {</b></p><p><b> int sel;</b></p&
108、gt;<p> Node *p,*r;</p><p> char findmess[20];</p><p> if(!l->next)</p><p> { system("cls");</p><p> printf("\n=====>沒(méi)有學(xué)生記錄!\n");&
109、lt;/p><p> getchar();</p><p><b> return;</b></p><p><b> }</b></p><p> system("cls");</p><p><b> Disp(l);</b>
110、;</p><p> printf("\n =====>1 按學(xué)號(hào)刪除 =====>2 按姓名刪除\n");</p><p> printf(" 請(qǐng)選擇[1,2]:");</p><p> scanf("%d",&sel);</p>
111、<p> if(sel==1)</p><p><b> {</b></p><p> stringinput(findmess,10,"輸入要?jiǎng)h除學(xué)生的學(xué)號(hào):");</p><p> p=Locate(l,findmess,"num");</p><p>
112、 if(p) /*p!=NULL*/</p><p><b> {</b></p><p><b> r=l;</b></p><p> while(r->next!=p)</p><p> r=r->next;</p><p> r->next=
113、p->next;/*將p所指節(jié)點(diǎn)從鏈表中去除*/</p><p> free(p); /*釋放內(nèi)存空間*/</p><p> printf("\n=====>刪除成功!\n");</p><p> getchar();</p><p> saveflag=1;</p><p>&
114、lt;b> }</b></p><p><b> else</b></p><p><b> Nofind();</b></p><p> getchar();</p><p><b> }</b></p><p> els
115、e if(sel==2) /*先按姓名查詢到該記錄所在的節(jié)點(diǎn)*/</p><p><b> {</b></p><p> stringinput(findmess,15,"輸入要?jiǎng)h除學(xué)生的姓名");</p><p> p=Locate(l,findmess,"name");</p>&
116、lt;p><b> if(p)</b></p><p><b> {</b></p><p><b> r=l;</b></p><p> while(r->next!=p)</p><p> r=r->next;</p><p&
117、gt; r->next=p->next;</p><p><b> free(p);</b></p><p> printf("\n=====>刪除成功!\n");</p><p> getchar();</p><p> saveflag=1;</p>&l
118、t;p><b> }</b></p><p><b> else</b></p><p><b> Nofind();</b></p><p> getchar();</p><p><b> }</b></p><p&
119、gt;<b> else</b></p><p><b> Wrong();</b></p><p> getchar();</p><p><b> }</b></p><p> /*修改學(xué)生記錄。先按輸入的學(xué)號(hào)查詢到該記錄,然后提示用戶修改學(xué)號(hào)之外的值,學(xué)號(hào)不能修
120、改*/</p><p> void Modify(Link l)</p><p><b> {</b></p><p><b> Node *p;</b></p><p> char findmess[20];</p><p> if(!l->next)<
121、;/p><p> { system("cls");</p><p> printf("\n=====>沒(méi)有學(xué)生記錄!\n");</p><p> getchar();</p><p><b> return;</b></p><p><b&g
122、t; }</b></p><p> system("cls");</p><p> printf("修改學(xué)生記錄");</p><p><b> Disp(l);</b></p><p> stringinput(findmess,10,"input
123、 the existing student number:"); /*輸入并檢驗(yàn)該學(xué)號(hào)*/</p><p> p=Locate(l,findmess,"num"); /*查詢到該節(jié)點(diǎn)*/</p><p> if(p) /*若p!=NULL,表明已經(jīng)找到該節(jié)點(diǎn)*/</p><p><b> {</b></
124、p><p> printf("學(xué)號(hào):%s,\n",p->data.num);</p><p> printf("姓名:%s,",p->data.name);</p><p> stringinput(p->data.name,15,"input new name:");</p>
125、;<p> printf("計(jì)算機(jī)成績(jī):%d,",p->data.cgrade);</p><p> p->data.cgrade=numberinput("Computer Score[0-100]:");</p><p> printf("高數(shù)成績(jī):%d,",p->data.mgrade)
126、;</p><p> p->data.mgrade=numberinput("Math Score[0-100]:");</p><p> printf("英語(yǔ)成績(jī):%d,",p->data.egrade);</p><p> p->data.egrade=numberinput("Engli
127、sh Score[0-100]:");</p><p> p->data.total=p->data.egrade+p->data.cgrade+p->data.mgrade;</p><p> p->data.ave=(float)(p->data.total/3);</p><p> p->data.mi
128、ngci=0;</p><p> printf("\n=====>修改成功!\n");</p><p><b> Disp(l);</b></p><p> saveflag=1;</p><p><b> }</b></p><p><
129、;b> else</b></p><p><b> Nofind();</b></p><p> getchar();</p><p><b> }</b></p><p> /*插入記錄:按學(xué)號(hào)查詢到要插入的節(jié)點(diǎn)的位置,然后在該學(xué)號(hào)之后插入一個(gè)新節(jié)點(diǎn)。*/</p&
130、gt;<p> void Insert(Link l)</p><p><b> {</b></p><p> Link p,v,newinfo; /*p指向插入位置,newinfo指新插入記錄*/</p><p> char ch,num[10],s[10]; /*s[]保存插入點(diǎn)位置之前的學(xué)號(hào),num[]保存輸入的新記
131、錄的學(xué)號(hào)*/</p><p> int flag=0;</p><p> v=l->next;</p><p> system("cls");</p><p><b> Disp(l);</b></p><p><b> while(1)</b&
132、gt;</p><p> { stringinput(s,10,"please input insert location after the Number:");</p><p> flag=0;v=l->next;</p><p> while(v) /*查詢?cè)搶W(xué)號(hào)是否存在,flag=1表示該學(xué)號(hào)存在*/</p>&
133、lt;p><b> {</b></p><p> if(strcmp(v->data.num,s)==0) {flag=1;break;}</p><p> v=v->next;</p><p><b> }</b></p><p> if(flag==1)</p&
134、gt;<p> break; /*若學(xué)號(hào)存在,則進(jìn)行插入之前的新記錄的輸入操作*/</p><p><b> else</b></p><p> { getchar();</p><p> printf("\n=====>學(xué)號(hào) %s 不存在,重新輸入?(y/n):",s);</p>
135、<p> scanf("%c",&ch);</p><p> if(ch=='y'||ch=='Y')</p><p> {continue;}</p><p><b> else</b></p><p><b> {return;
136、}</b></p><p><b> }</b></p><p><b> }</b></p><p> /*以下新記錄的輸入操作與Add()相同*/</p><p> stringinput(num,10,"input new student Number:"
137、;);</p><p> v=l->next;</p><p><b> while(v)</b></p><p><b> {</b></p><p> if(strcmp(v->data.num,num)==0)</p><p><b>
138、{</b></p><p> printf("=====>對(duì)不起,學(xué)號(hào):'%s' 重復(fù) !\n",num);</p><p> printheader();</p><p> printdata(v);</p><p> printf("\n");</p&
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生成績(jī)信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)報(bào)告+學(xué)生成績(jī)信息管理系統(tǒng)+源代碼
- 信息管理系統(tǒng)課程設(shè)計(jì)——學(xué)生成績(jī)管理系統(tǒng)
- 課程設(shè)計(jì)-- 學(xué)生成績(jī)信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)--職工信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)--- 學(xué)生信息管理系統(tǒng)
- 職工信息管理系統(tǒng)c語(yǔ)言課程設(shè)計(jì)
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)——學(xué)生信息管理系統(tǒng)
- 教師信息管理系統(tǒng)(c語(yǔ)言課程設(shè)計(jì))
- c語(yǔ)言課程設(shè)計(jì)---學(xué)生信息管理系統(tǒng)
- 學(xué)生信息管理系統(tǒng)-c語(yǔ)言課程設(shè)計(jì)
- c語(yǔ)言課程設(shè)計(jì)——歌曲信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)職工信息管理系統(tǒng)
- 學(xué)生成績(jī)信息管理系統(tǒng) 課程設(shè)計(jì)2
- delphi課程設(shè)計(jì)--學(xué)生成績(jī)信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)---學(xué)生信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)---職工信息管理系統(tǒng)
評(píng)論
0/150
提交評(píng)論