c語言成績信息管理系統(tǒng)課程設(shè)計(jì)--成績信息管理系統(tǒng)_第1頁
已閱讀1頁,還剩35頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、<p>  《C語言程序設(shè)計(jì)》課程設(shè)計(jì)報(bào)告</p><p>  專 業(yè): 電子信息工程 </p><p>  班 級: </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 所涉及知識點(diǎn) ……………………………………………3 </p><p>  3.2課程設(shè)計(jì)的思路以及流程圖 ……………………………3 </p><p>  3.3個人負(fù)責(zé)程序說明 ………………………………………4</p><p>  3.4課程設(shè)計(jì)中遇到的問題以及解決方法 …………………11 </p><p>  4.個人設(shè)計(jì)總

4、結(jié)…………………………………………………11 </p><p>  5.參考書目………………………………………………………11 </p><p>  6.附錄源程序代碼………………………………………………11</p><p>  《C語言程序設(shè)計(jì)》課程設(shè)計(jì)任務(wù)書</p><p><b>  1、課程設(shè)計(jì)目的</b><

5、;/p><p> ?。?)、熟練掌握C語言課程中所學(xué)的理論知識;</p><p>  (2)、通過綜合C語言的基本知識來解決實(shí)際問題;</p><p> ?。?)、加強(qiáng)分析和解決問題的能力。</p><p>  2、課程設(shè)計(jì)題目描述和要求</p><p> ?。?)課程設(shè)計(jì)題目:成績信息管理系統(tǒng)。</p>&

6、lt;p> ?。?)課程設(shè)計(jì)要求:</p><p>  a,設(shè)計(jì)包含N個學(xué)生的數(shù)據(jù)信息的學(xué)生成績管理系統(tǒng),包括以下信息: </p><p>  學(xué)號、 姓名(拼音)、三門課程成績(高數(shù)、英語、計(jì)算機(jī)) </p><p>  b,系統(tǒng)功能包括: </p><p>  1、學(xué)生信息的錄入(增加數(shù)據(jù))。用數(shù)組數(shù)據(jù)類型賦初值的方法或從鍵盤輸入的

7、方法把學(xué)生的數(shù)據(jù)送到各個數(shù)組中(注意要是合法數(shù)據(jù)),然后把它們輸出顯示。</p><p>  2、學(xué)生信息的刪除(刪除數(shù)據(jù))。任意輸入一位學(xué)生的學(xué)號,將它所有的信息從數(shù)組中刪除。</p><p>  3、學(xué)生信息的瀏覽(查找數(shù)據(jù))。任意輸入一位學(xué)生的學(xué)號,打印出他的所有數(shù)據(jù)。要求能多次查找。</p><p>  4、學(xué)生信息的修改(修改數(shù)據(jù))。任意輸入一位學(xué)生的學(xué)號

8、,打印出所有相關(guān)信息后,可對某一項(xiàng)信息進(jìn)行修改并保存。</p><p>  5、學(xué)生信息的計(jì)算并排序。計(jì)算每個學(xué)生三門課程的總分(sum,整型)及平均分(aver,單精度,輸出一位小數(shù)),將包括所有數(shù)據(jù)的數(shù)組元素按總分從大到小的順序排序打印出來。</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. 所涉及知識點(diǎn):</p><p>  指針的定義與引用;函數(shù)的定義與調(diào)用;局部變量和全局變量大的定義; for循環(huán)語句的使用;if語句的使用;break語句的使用;格式輸入與輸出;比較法排序;函數(shù)的定義;數(shù)組作為函數(shù)參數(shù)。</p><p>  3.2課程設(shè)計(jì)的思路以及流程圖</p><p>

11、<b>  一:課程設(shè)計(jì)思路</b></p><p>  主程序?yàn)閙ain(),子程序有個分別為Add(l),Qur(l), Modify(l), Insert(l), Tongji(l), Sort(l), Save(l)。分別可以實(shí)現(xiàn)錄入學(xué)生信息,刪除學(xué)生信息,瀏覽學(xué)生信息,修改學(xué)生信息,對信息學(xué)生排序,以及對學(xué)生信息保存。</p><p>  二、課程設(shè)計(jì)思路及

12、結(jié)構(gòu)圖</p><p>  根據(jù)題目的要求,需要一個主程序main()和若干子程序,其如結(jié)構(gòu)圖下:</p><p>  1、初始化函數(shù) STUDENT  *init()</p><p>  這是一個無參函數(shù),里面只有一個語句,它的作用是使鏈表初始化,使head的值為NULL。比如:沒有這個函數(shù)的話,在你沒有輸入任何數(shù)據(jù)的情況下,去執(zhí)行顯示功能的時(shí)候會顯示一

13、些亂碼!</p><p>  2、菜單選擇函數(shù) int menu_select();</p><p>  這是一個無參函數(shù),主要實(shí)現(xiàn)“功能選擇”的界面,在這個界面里有顯示系統(tǒng)的九大功能,根據(jù)每個功能前面的序號進(jìn)行選擇,中間還顯示系統(tǒng)當(dāng)前的時(shí)間。等執(zhí)行完每一個函數(shù)功能后,按任一鍵回到主界面也要通過這個函數(shù)來實(shí)現(xiàn)!</p><p>  3、輸入記錄函數(shù) STUDENT

14、*create()</p><p>  這是一個無參函數(shù),用來執(zhí)行第學(xué)生成績記錄的輸入,當(dāng)學(xué)生為0時(shí)停止輸入,函數(shù)結(jié)束后,帶回一個指向鏈表頭的指針head。</p><p>  算法:先聲明一個首節(jié)點(diǎn)head,并將head->next設(shè)為NULL。每輸入一個數(shù)據(jù)就聲明一個新節(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>  這是一個不返回值的有參函數(shù),形參為“鏈表頭的指針”,負(fù)責(zé)對全部學(xué)生成績記錄的輸出,不足之處就是不能對學(xué)生成績進(jìn)行分頁顯示。</p><p>  算法:先將p結(jié)點(diǎn)的指針指向第一個結(jié)點(diǎn),將p結(jié)點(diǎn)(即第

16、一個結(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>  這是一個不返回值的有參函

17、數(shù),形參為“鏈表頭的指針”,實(shí)現(xiàn)按學(xué)號對某個學(xué)生進(jìn)行查找,并顯示所查找到的記錄。</p><p>  算法:采用線性查找法往下一個節(jié)點(diǎn)查找。輸入所要查找的學(xué)生的學(xué)號s,設(shè)一個指針變量p,先指向第一個結(jié)點(diǎn),當(dāng)strcmp(p->name,s) && p != NULL時(shí),使p后移一個結(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é)號查詢*/</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é)號*/</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; /*若未找到,返回一個空指針*/</p><p><b>  }</b></p><p>  /*輸入字符串,并進(jìn)行長度驗(yàn)證(長度<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)行長度校驗(yàn),超過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 成績范圍[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>  這是一個有參函數(shù),形參為“鏈表頭的指針”,先輸入要刪除的學(xué)生記錄的學(xué)號,找到后顯示該學(xué)生信息,等確認(rèn)后便可按“Y”進(jìn)行刪除。</p><p>  算法:從p指向的第一個結(jié)點(diǎn)開始,檢查該結(jié)點(diǎn)中的num值是否等于輸入的要求刪除的那個學(xué)號。如

32、果相等就將該結(jié)點(diǎn)刪除,如不相等,就將p后移一個結(jié)點(diǎn),再如此進(jìn)行下去,直到遇到表尾為止。</p><p><b>  N-S流程圖如下:</b></p><p>  7、排序函數(shù) STUDENT *sort(STUDENT *head)</p><p>  這是一個有參函數(shù),形參為“鏈表頭的指針”,按學(xué)生成績的平均分高低進(jìn)行排序,還可以顯示名次。

33、</p><p><b>  N-S流程圖:</b></p><p>  8、插入函數(shù) STUDENT *insert(STUDENT *head,STUDENT *new)</p><p>  這是一個有參函數(shù),形參有兩個,一個是“鏈表頭的指針”,一個是“待插入指針”,按照原來成績平均分的高低進(jìn)行插入,插入后會重新進(jìn)行排序,并返回。</

34、p><p>  算法:先將學(xué)生的成績按平均分由高分到低分進(jìn)行排序,再插入一個新生的結(jié)點(diǎn),要求按平均分的高低順序插入。先用指針變量p0指向待插入的結(jié)點(diǎn),p1指向第一個結(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)插到鏈表末尾。如果插入的位置既不在第一個結(jié)點(diǎn)之前,又不在表尾結(jié)點(diǎn)之后,則將p0的值賦給p2->,使p2->next指向待插入的結(jié)點(diǎn),然后將p1的值賦給p0->next,使得p0->next指向p1指向的變量。如果插入位置為第一個結(jié)點(diǎn)之前

36、,則將p0賦給head,將p1賦給p0->next。如果要插到表尾之后,應(yīng)將p0賦給p1->next,NULL賦給p0->next。最后再調(diào)用排序的函數(shù),將學(xué)生成績重新排序.</p><p><b>  N-S流程圖如下:</b></p><p>  9、保存數(shù)據(jù)到文件函數(shù) void save(STUDENT *head)</p>&l

37、t;p>  這是一個不返回值的有參函數(shù),形參為“鏈表頭的指針”,可以把學(xué)生記錄保存在電腦上由自己任意命名的二進(jìn)制文件。</p><p><b>  N-S流程圖如下:</b></p><p>  10、從文件讀數(shù)據(jù)函數(shù) STUDENT *load()</p><p>  這是一個不返回值的有參函數(shù),形參為“鏈表頭的指針”,根據(jù)輸入的文件地

38、址進(jìn)行讀取。</p><p><b>  N-S流程圖如下:</b></p><p>  3.3 個人負(fù)責(zé)程序說明</p><p>  學(xué)生信息的瀏覽(查找數(shù)據(jù))。任意輸入一位學(xué)生的學(xué)號,打印出他的所有數(shù)據(jù)。要求能多次查找。</p><p>  3.4課程設(shè)計(jì)中遇到的問題以及解決方法</p><p&g

39、t; ?。?)剛開始沒有那個初始化函數(shù),程序運(yùn)行后,沒有輸入任何數(shù)據(jù)就試得去執(zhí)行顯示功能,結(jié)果顯示的是一些亂碼!加入初始化函數(shù)后,這種現(xiàn)象也隨之消失。</p><p>  (2)剛開始時(shí),先把成績按平均分排序,再插入一個學(xué)生的成績,執(zhí)行顯示功能,雖然插入的學(xué)生的成績能正常插入,但該學(xué)生的名次為0。后來,在插入成績之后,調(diào)用排序函數(shù),把所有成績重新排序一次。</p><p> ?。?)在輸入

40、函數(shù)中設(shè)了一個無限循環(huán),可以輸入無數(shù)個學(xué)生的成績信息,當(dāng)學(xué)號為0的時(shí)候則停止輸入。</p><p> ?。?)輸入太多個學(xué)生的成績時(shí),屏幕顯示不能控制為一頁一頁顯示,所以為了方便起見,不要輸入太多記錄,十七左右為最佳。</p><p> ?。?)在沒有輸入任何信息的情況下,去執(zhí)行排序功能,最后顯示有一個記錄,學(xué)號、姓名為空白,成績都為0,名次為1。</p><p>

41、 ?。?)在輸入選項(xiàng)時(shí)不能輸入字母,否則會死循環(huán),建議不要亂輸字母。</p><p><b>  4、個人設(shè)計(jì)總結(jié)</b></p><p>  C語言課程設(shè)計(jì),感覺自己收獲了不少,通過這個課程設(shè)計(jì)提高了對編程語言的興趣,同時(shí)加深了對C語言的理解!</p><p>  本來按老師建議的是用結(jié)構(gòu)體數(shù)組,但是由于沒有學(xué)習(xí)結(jié)構(gòu)體數(shù)組,而自己自學(xué)起來我們

42、個人感覺指針更簡單一些,所以采用了指針的方法。</p><p>  鏈表本來上課是沒有學(xué)的,但這個課程設(shè)計(jì)里面主要都是用鏈表,因?yàn)橐_(dá)到這樣的功能,使用鏈表相當(dāng)方便,但不容易理解,所以在這方面我很了很多的時(shí)間看課本和參考課外書,使C語言的知識強(qiáng)化了不少。</p><p>  在做課程設(shè)計(jì)的過程中,發(fā)現(xiàn)了平時(shí)很多沒有注意到的問題,例如:返回值函數(shù)和不返回值函數(shù)兩者在主函數(shù)中的調(diào)用是不同的等等

43、。</p><p>  這次課程設(shè)計(jì)雖然花了我不少時(shí)間,但正是這些時(shí)間,讓我見識到了C語言的重要性。</p><p><b>  5、參考書目</b></p><p>  Schildt H著,戴健鵬譯,C語言大全(第二版),電子工業(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ù)庫*/</p><p>  #include &quo

45、t;stdlib.h" /*標(biāo)準(zhǔn)函數(shù)庫*/</p><p>  #include "string.h" /*字符串函數(shù)庫*/</p><p>  #include "conio.h" /*屏幕操作函數(shù)庫*/</p><p>  #define HEADER1 " ------------------

46、----------學(xué)生成績表---------------------------------- \n"</p><p>  #define HEADER2 " | 學(xué)號 | 姓名 |計(jì)算機(jī)|數(shù)學(xué)|英語 | 總分 | 平均分 |名次 | \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; /*是否需要存盤的標(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é)號*/</p><p>  char name[15]; /*姓名*/</p><p>  int cgrade; /*計(jì)算機(jī)成績*/</p><p>  int mgrade; /*數(shù)學(xué)成績*/<

51、/p><p>  int egrade; /*英語成績*/</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é)生成績管理系統(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() /*輸出按鍵錯誤信息*/</p><p><b>  {</b></p><p>  printf("\n\n\n\n\n***********錯誤:輸入有誤! 按任意鍵繼續(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中存儲的學(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存儲的是單鏈表中頭結(jié)點(diǎn)的指針,該頭結(jié)

64、點(diǎn)沒有存儲學(xué)生信息,指針域指向的后繼結(jié)點(diǎn)才有學(xué)生信息*/</p><p>  if(!p) /*p==NULL,NUll在stdlib中定義為0*/</p><p><b>  {</b></p><p>  printf("\n=====>沒有學(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) /*逐條輸出鏈表中存儲的學(xué)生信息*/</p><p><b>  {</b></p><p>  printdata(p);</p><p>  p=p->next; /*移動直下一個結(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é)號查詢*/</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é)號*/</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; /*若未找到,返回一個空指針*/</p><p><b>  }</b></p><p>  /*輸入字符串,并進(jìn)行長度驗(yàn)證(長度<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)行長度校驗(yàn),超過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 成績范圍[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é)號為0的記錄結(jié)點(diǎn)添加操作*/</p><p><b>  {</b></p><p>

83、;  while(1) /*輸入學(xué)號,保證該學(xué)號沒有被使用,若輸入學(xué)號為0,則退出添加記錄操作*/</p><p><b>  {</b></p><p>  stringinput(num,10,"輸入學(xué)號(按'0'返回菜單):"); /*格式化輸入學(xué)號并檢驗(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) /*查詢該學(xué)號是

85、否已經(jīng)存在,若存在則要求重新輸入一個未被占用的學(xué)號*/</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é)號 %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)); /*申請內(nèi)存空間*/</p><p><b>  if(!p)</b></p><p><b>  {</b

90、></p><p>  printf("\n 分配失敗 "); /*如沒有申請到,打印提示信息*/</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é)號或姓名,查詢學(xué)生記錄*/</p><p><b>  {</b></p&g

96、t;<p>  int select; /*1:按學(xué)號查,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=====>沒有學(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é)號查詢 =====>2 按姓名查詢\n");</p><p>  printf(&q

99、uot; 請選擇[1,2]:");</p><p>  scanf("%d",&select);</p><p>  if(select==1) /*按學(xué)號查詢*/</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é)號為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=====>沒有學(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é)號刪除 =====>2 按姓名刪除\n");</p><p>  printf(" 請選擇[1,2]:");</p><p>  scanf("%d",&sel);</p>

111、<p>  if(sel==1)</p><p><b>  {</b></p><p>  stringinput(findmess,10,"輸入要刪除學(xué)生的學(xué)號:");</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,"輸入要刪除學(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é)號查詢到該記錄,然后提示用戶修改學(xué)號之外的值,學(xué)號不能修

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=====>沒有學(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é)號*/</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é)號:%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ī)成績:%d,",p->data.cgrade);</p><p>  p->data.cgrade=numberinput("Computer Score[0-100]:");</p><p>  printf("高數(shù)成績:%d,",p->data.mgrade)

126、;</p><p>  p->data.mgrade=numberinput("Math Score[0-100]:");</p><p>  printf("英語成績:%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é)號查詢到要插入的節(jié)點(diǎn)的位置,然后在該學(xué)號之后插入一個新節(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é)號,num[]保存輸入的新記

131、錄的學(xué)號*/</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) /*查詢該學(xué)號是否存在,flag=1表示該學(xué)號存在*/</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é)號存在,則進(jìn)行插入之前的新記錄的輸入操作*/</p><p><b>  else</b></p><p>  { getchar();</p><p>  printf("\n=====>學(xué)號 %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("=====>對不起,學(xué)號:'%s' 重復(fù) !\n",num);</p><p>  printheader();</p><p>  printdata(v);</p><p>  printf("\n");</p&

溫馨提示

  • 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論