數(shù)據(jù)庫課程設(shè)計---利用鏈?zhǔn)絻Υ鎸W(xué)生成績進行基本操作_第1頁
已閱讀1頁,還剩17頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p>  利用鏈?zhǔn)絻Υ鎸W(xué)生成績進行基本操作</p><p>  數(shù) 據(jù) 結(jié) 構(gòu) 課 程 設(shè) 計</p><p>  設(shè)計題目:利用鏈?zhǔn)絻Υ鎸W(xué)生成績進行基本操作 </p><p>  學(xué)生姓名: </p><p>  專業(yè)班級:

2、 </p><p>  指導(dǎo)教師: </p><p>  完成時間: </p><p><b>  學(xué)院 系</b></p><p> 

3、 ********課程設(shè)計成績評定表(本科)</p><p><b>  目 錄 </b></p><p>  第一章.課程設(shè)計的目的及要求1</p><p>  第二章.課程設(shè)計的內(nèi)容和要求1</p><p><b>  2.1內(nèi)容1</b></p><p>&l

4、t;b>  2.2要求1</b></p><p>  第三章.課程設(shè)計分析分析1</p><p>  3.1設(shè)計思路及方案1</p><p>  3.2模塊設(shè)計與介紹3</p><p>  3.2.1結(jié)構(gòu)類型聲明部分3</p><p>  3.2.2類型域聲明部分3</p>

5、<p>  3.2.3置空鏈表部分3</p><p>  3.2.4創(chuàng)建鏈表部分3</p><p>  3.2.5查找學(xué)生信息部分4</p><p>  3.2.6輸出學(xué)生信息部分4</p><p>  3.2.7插入學(xué)生信息部分5</p><p>  3.2.8刪除學(xué)生信息部分5</p&g

6、t;<p>  3.2.9對學(xué)生信息進行排序部分5</p><p>  3.2.10主函數(shù)部分6</p><p>  第四章 算法描述7</p><p>  第五章 數(shù)據(jù)結(jié)構(gòu)描述與定義7</p><p><b>  5.1結(jié)構(gòu)題:7</b></p><p>  5.2結(jié)構(gòu)體

7、數(shù)組:8</p><p>  5.3程序架構(gòu)圖8</p><p><b>  第六章.源程序8</b></p><p>  第七章 運行結(jié)果分析12</p><p>  第八章.結(jié)束語14</p><p>  第九章.參考文獻15</p><p>  第一章.課

8、程設(shè)計的目的及要求</p><p>  此次設(shè)計意義在于讓我們更好的去掌握C的基本語法、函數(shù)以及Visual C++集成編譯環(huán)境。單鏈表的鏈?zhǔn)絻Υ娴然緮?shù)據(jù)結(jié)構(gòu)及其應(yīng)用。掌握程序流程以及基本應(yīng)用方法。</p><p>  通過本課程設(shè)計,培養(yǎng)我們進行課程設(shè)計能力。</p><p>  在當(dāng)今信息爆炸的時代,如何采用較好的信息技術(shù)對一些數(shù)據(jù)元素進行基本操作來為人類很好

9、地服務(wù)。線性表的鏈?zhǔn)絻Υ嬲且环N應(yīng)用廣泛且非常有效的數(shù)據(jù)處理技術(shù)。</p><p>  第二章.課程設(shè)計的內(nèi)容和要求</p><p><b>  2.1內(nèi)容</b></p><p>  (1).創(chuàng)建線性表。</p><p>  (2).實現(xiàn)對線性表的鏈?zhǔn)絻Υ鎸W(xué)生成績進行基本操作,包括插入、刪除、查找,排序等操作。<

10、;/p><p><b>  2.2要求</b></p><p><b>  硬件: 計算機</b></p><p>  軟件: Windows Microsoft Visual C++6.0</p><p>  第三章.課程設(shè)計分析分析</p><p>  3.1設(shè)計思路及方

11、案</p><p>  本課題是用線性表的鏈?zhǔn)絻Υ鎭韺W(xué)生進行基本操作的功能。設(shè)計思路及方案,可用流程圖來表示。</p><p><b>  圖1函數(shù)主流程圖</b></p><p><b>  繼續(xù)輸入</b></p><p>  圖2 建立學(xué)生信息鏈表</p><p>

12、<b>  N</b></p><p><b>  Y</b></p><p>  圖3 刪除信息流程成圖</p><p><b>  N</b></p><p><b>  Y</b></p><p>  圖4 查找信息流程圖&

13、lt;/p><p>  3.2模塊設(shè)計與介紹</p><p>  3.1.1結(jié)構(gòu)類型聲明部分</p><p>  #include<stdio.h></p><p>  typedef struct</p><p><b>  {</b></p><p><b

14、>  int num;</b></p><p>  char name[20];</p><p>  float score;</p><p><b>  }std;</b></p><p>  3.2.2類型域聲明部分</p><p>  typedef int datatyp

15、e;</p><p>  typedef struct node</p><p><b>  {</b></p><p><b>  std data;</b></p><p>  struct node *next;</p><p>  }linklist;</p&

16、gt;<p>  3.2.3置空鏈表部分</p><p>  void setnull(linklist *head)</p><p><b>  {</b></p><p>  head=(linklist *)malloc(sizeof(linklist));</p><p>  head->ne

17、xt=NULL;</p><p><b>  }</b></p><p>  3.2.4創(chuàng)建鏈表部分</p><p>  void creatlist(linklist *head,int n)</p><p><b>  {</b></p><p><b>  i

18、nt i;</b></p><p>  linklist *p,*tail;</p><p>  tail=head;</p><p>  for(i=1;i<=n;i++)</p><p><b>  {</b></p><p>  p=(linklist *)malloc(s

19、izeof(linklist));</p><p>  printf("請輸入第%d個學(xué)生的基本信息:",i);</p><p>  scanf("%d%s%f",&p->data.num,&p->data.name,&p->data.score);</p><p>  p->n

20、ext=NULL;</p><p>  tail->next=p;</p><p><b>  tail=p;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  3.2.5查找學(xué)生信息部分&

21、lt;/p><p>  linklist *get(linklist *head,int i)</p><p><b>  {</b></p><p><b>  int j=0;</b></p><p>  linklist *p;</p><p><b>  p=h

22、ead;</b></p><p>  while(p->next!=NULL&&j<i)</p><p><b>  {</b></p><p><b>  j++;</b></p><p>  p=p->next;</p><p&g

23、t;<b>  }</b></p><p><b>  if(j==i)</b></p><p><b>  return p;</b></p><p><b>  else</b></p><p>  return NULL;</p>&l

24、t;p><b>  }</b></p><p>  3.2.6輸出學(xué)生信息部分</p><p>  void print(linklist *head)</p><p><b>  {</b></p><p>  linklist *p;</p><p>  p=hea

25、d->next;</p><p>  while(p!=NULL)</p><p><b>  {</b></p><p>  printf("%d\t%s\t%f\n",p->data.num,p->data.name,p->data.score);</p><p>  p=

26、p->next;</p><p><b>  }</b></p><p><b>  }</b></p><p>  3.2.7插入學(xué)生信息部分</p><p>  void insertafter(linklist *p,int i)</p><p><b>

27、;  {</b></p><p>  linklist *s;</p><p><b>  int j;</b></p><p>  printf("請輸入要插入的學(xué)生信息:");</p><p>  s=(linklist *)malloc(sizeof(linklist));</

28、p><p>  scanf("%d%s%f",&s->data.num,&s->data.name,&s->data.score);</p><p>  while(p!=NULL&&j<i)</p><p><b>  {</b></p><p

29、><b>  j++;</b></p><p>  p=p->next;</p><p><b>  }</b></p><p><b>  if(j==i)</b></p><p><b>  {</b></p><p&g

30、t;  s->next=p->next;</p><p>  p->next=s;</p><p><b>  }</b></p><p><b>  }</b></p><p>  3.2.8刪除學(xué)生信息部分</p><p>  void deleteaf

31、ter(linklist *p)</p><p><b>  {</b></p><p>  linklist *q;</p><p>  q=p->next;</p><p>  p->next=q->next;</p><p><b>  free(q);</

32、b></p><p><b>  }</b></p><p>  3.2.9對學(xué)生信息進行排序部分</p><p>  void sort(linklist *head)</p><p><b>  {</b></p><p>  linklist *p;</p&

33、gt;<p><b>  std t;</b></p><p>  p=head->next;</p><p>  if(p->data.score<p->next->data.score)</p><p><b>  {</b></p><p>  t=

34、p->data;</p><p>  p->data=p->next->data;</p><p>  p->next->data=t;</p><p><b>  }</b></p><p><b>  }</b></p><p>  3

35、.2.10主函數(shù)部分</p><p>  void main()</p><p><b>  { </b></p><p>  linklist *p,head;</p><p><b>  int i=1;</b></p><p><b>  while(i)

36、</b></p><p><b>  {</b></p><p>  printf("0:初始化\n1:建立學(xué)生成績表\n2:查找\n3:插入\n4:刪除\n5:輸出\n6:排序\n");</p><p>  scanf("%d",&i);</p><p>&l

37、t;b>  switch(i)</b></p><p><b>  {</b></p><p><b>  case 0:</b></p><p>  setnull(&head);break;</p><p><b>  case 1:</b><

38、;/p><p>  printf("請輸入要創(chuàng)建的結(jié)點的個數(shù):");</p><p>  scanf("%d",&i);</p><p>  creatlist(&head,i);break;</p><p><b>  case 2:</b></p>&

39、lt;p>  printf("請輸入要查找的位置:");</p><p>  scanf("%d",&i);</p><p>  p=get(&head,i);</p><p>  printf("%d\t%s\t%f\n",p->data.num,p->data.name

40、,p->data.score);break;</p><p><b>  case 3:</b></p><p>  printf("請輸入要插入的位置:");</p><p>  scanf("%d",&i);</p><p>  insertafter(&

41、head,i);break;</p><p><b>  case 4:</b></p><p>  deleteafter(p);break;</p><p><b>  case 5:</b></p><p>  print(&head);break;</p><p&

42、gt;  case 6:sort(&head);break;</p><p><b>  }</b></p><p>  printf("\n0:結(jié)束\n1:繼續(xù)\n");</p><p>  scanf("%d",&i);</p><p><b>  }

43、</b></p><p><b>  }</b></p><p><b>  第四章 算法描述</b></p><p>  編寫一個程序來管理學(xué)生成績,本系統(tǒng)能實現(xiàn)以下功能:(1)輸入學(xué)生信息:輸入學(xué)生學(xué)號、姓名以及成績.(2)插入學(xué)生信息:在指定位置插入學(xué)生信息;添加新學(xué)生信息.(3)刪除學(xué)生信息:刪除

44、指定學(xué)生信息;(4)查詢學(xué)生信息:根據(jù)姓名查詢某個學(xué)生的成績;根據(jù)學(xué)號區(qū)間段查詢(5)對學(xué)生成績進行排序:根據(jù)要求,能按學(xué)生的成績對學(xué)生進行排序,并顯示排序后的結(jié)果.(6)輸出:輸出所有學(xué)生信息.</p><p>  第五章 數(shù)據(jù)結(jié)構(gòu)描述與定義 </p><p><b>  5.1結(jié)構(gòu)題: </b></p><p>  “結(jié)構(gòu)體名”用作結(jié)

45、構(gòu)體類型的標(biāo)志,它又稱“結(jié)構(gòu)體標(biāo)記”。聲明一個結(jié)構(gòu)體類型的一般形式為: </p><p>  Struct 結(jié)構(gòu)體名 </p><p><b>  { 成員表列</b></p><p><b>  }; </b></p><p>  大括弧內(nèi)是該結(jié)構(gòu)體中的各個成員,由它們組成一個結(jié)構(gòu)體。對各成員都應(yīng)

46、進行類型聲明,即 類型名 成員名 </p><p>  也可以把“成員表列”稱為“域表”。每一個成員也稱為結(jié)構(gòu)體中的一個域。成員名定名規(guī)與變量名同。</p><p>  5.2結(jié)構(gòu)體數(shù)組: </p><p>  一個結(jié)構(gòu)體變量中可以存放一組數(shù)據(jù)(如本程序中一個學(xué)生的學(xué)號、姓名、成績)。因為程序中需存放若干個學(xué)生的信息,這些數(shù)據(jù)需要參加運算,就得運用數(shù)組即結(jié)構(gòu)體數(shù)組

47、。結(jié)構(gòu)體數(shù)組的每個數(shù)組元素都是一個結(jié)構(gòu)體類型的數(shù)據(jù),它們分別包括各個成員(分量)項。 </p><p><b>  5.3程序架構(gòu)圖</b></p><p><b>  第六章.源程序</b></p><p>  #include<stdio.h></p><p>  typedef s

48、truct</p><p><b>  {</b></p><p><b>  int num;</b></p><p>  char name[20];</p><p>  float score;</p><p><b>  }std;</b><

49、;/p><p>  typedef int datatype;</p><p>  typedef struct node</p><p><b>  {</b></p><p><b>  std data;</b></p><p>  struct node *next;&

50、lt;/p><p>  }linklist;</p><p>  void setnull(linklist *head)</p><p><b>  {</b></p><p>  head=(linklist *)malloc(sizeof(linklist));</p><p>  head-&

51、gt;next=NULL;</p><p><b>  }</b></p><p>  void creatlist(linklist *head,int n)</p><p><b>  {</b></p><p><b>  int i;</b></p>&l

52、t;p>  linklist *p,*tail;</p><p>  tail=head;</p><p>  for(i=1;i<=n;i++)</p><p><b>  {</b></p><p>  p=(linklist *)malloc(sizeof(linklist));</p>

53、<p>  printf("請輸入第%d個學(xué)生的基本信息:",i);</p><p>  scanf("%d%s%f",&p->data.num,&p->data.name,&p->data.score);</p><p>  p->next=NULL;</p><p>

54、;  tail->next=p;</p><p><b>  tail=p;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  linklist *get(linklist *head,int i)</p&g

55、t;<p><b>  {</b></p><p><b>  int j=0;</b></p><p>  linklist *p;</p><p><b>  p=head;</b></p><p>  while(p->next!=NULL&&

56、amp;j<i)</p><p><b>  {</b></p><p><b>  j++;</b></p><p>  p=p->next;</p><p><b>  }</b></p><p><b>  if(j==i)&

57、lt;/b></p><p><b>  return p;</b></p><p><b>  else</b></p><p>  return NULL;</p><p><b>  }</b></p><p>  void print(li

58、nklist *head)</p><p><b>  {</b></p><p>  linklist *p;</p><p>  p=head->next;</p><p>  while(p!=NULL)</p><p><b>  {</b></p>

59、<p>  printf("%d\t%s\t%f\n",p->data.num,p->data.name,p->data.score);</p><p>  p=p->next;</p><p><b>  }</b></p><p><b>  }</b><

60、/p><p>  void insertafter(linklist *p,int i)</p><p><b>  {</b></p><p>  linklist *s;</p><p><b>  int j;</b></p><p>  printf("請輸入要

61、插入的學(xué)生信息:");</p><p>  s=(linklist *)malloc(sizeof(linklist));</p><p>  scanf("%d%s%f",&s->data.num,&s->data.name,&s->data.score);</p><p>  while(p

62、!=NULL&&j<i)</p><p><b>  {</b></p><p><b>  j++;</b></p><p>  p=p->next;</p><p><b>  }</b></p><p><b>

63、;  if(j==i)</b></p><p><b>  {</b></p><p>  s->next=p->next;</p><p>  p->next=s;</p><p><b>  }</b></p><p><b>  

64、}</b></p><p>  void deleteafter(linklist *p)</p><p><b>  {</b></p><p>  linklist *q;</p><p>  q=p->next;</p><p>  p->next=q->nex

65、t;</p><p><b>  free(q);</b></p><p><b>  }</b></p><p>  void sort(linklist *head)</p><p><b>  {</b></p><p>  linklist *p

66、;</p><p><b>  std t;</b></p><p>  p=head->next;</p><p>  if(p->data.score<p->next->data.score)</p><p><b>  {</b></p><p

67、>  t=p->data;</p><p>  p->data=p->next->data;</p><p>  p->next->data=t;</p><p><b>  }</b></p><p><b>  }</b></p><

68、p>  void main()</p><p><b>  { </b></p><p>  linklist *p,head;</p><p><b>  int i=1;</b></p><p><b>  while(i)</b></p><

69、p><b>  {</b></p><p>  printf("0:初始化\n1:建立學(xué)生成績表\n2:查找\n3:插入\n4:刪除\n5:輸出\n6:排序\n");</p><p>  scanf("%d",&i);</p><p><b>  switch(i)</b&g

70、t;</p><p><b>  {</b></p><p><b>  case 0:</b></p><p>  setnull(&head);break;</p><p><b>  case 1:</b></p><p>  printf

71、("請輸入要創(chuàng)建的結(jié)點的個數(shù):");</p><p>  scanf("%d",&i);</p><p>  creatlist(&head,i);break;</p><p><b>  case 2:</b></p><p>  printf("請輸入

72、要查找的位置:");</p><p>  scanf("%d",&i);</p><p>  p=get(&head,i);</p><p>  printf("%d\t%s\t%f\n",p->data.num,p->data.name,p->data.score);break;&

73、lt;/p><p><b>  case 3:</b></p><p>  printf("請輸入要插入的位置:");</p><p>  scanf("%d",&i);</p><p>  insertafter(&head,i);break;</p>

74、<p><b>  case 4:</b></p><p>  deleteafter(p);break;</p><p><b>  case 5:</b></p><p>  print(&head);break;</p><p>  case 6:sort(&head

75、);break;</p><p><b>  }</b></p><p>  printf("\n0:結(jié)束\n1:繼續(xù)\n");</p><p>  scanf("%d",&i);</p><p><b>  } </b></p>&l

76、t;p><b>  }</b></p><p>  第七章 運行結(jié)果分析</p><p>  圖6 菜單設(shè)置有初始化、建表、查找、插入、刪除、輸出、排序功能</p><p>  圖7 初始化功能的實現(xiàn)</p><p>  圖8 建表、輸出功能的實現(xiàn)</p><p>  圖9 插

77、入、排序功能的實現(xiàn)</p><p><b>  第八章.結(jié)束語</b></p><p>  在這段時間的課程設(shè)計使我對線性表的鏈?zhǔn)絻Υ嬗辛烁畹恼J識和理解,也使我更加明白線性表的鏈?zhǔn)絻Υ嬖谛畔⒓夹g(shù)中的重要性和地位。</p><p>  通過本次課程設(shè)計期間我遇到的一些難點。開始的時候,代碼中有許多的錯誤,特別是有一些調(diào)試方面的錯誤讓我束手無策,

78、最后在我強大的毅力下慢慢地改正錯誤才讓我又看到了希望。</p><p>  許多的錯誤讓我明白了一個道理---毅力和信心對成功是非常重要的。同時,對于編程者而言,思路清晰是相當(dāng)重要的。在適當(dāng)?shù)臅r候和同學(xué)一起交流探討是一個十分好的學(xué)習(xí)機會。請教老師也很重要,因為畢竟我們是新手,對于某些問題很難弄清楚。而且,某些錯誤對于我們來說有時候想半天都弄不來,但老師幾下下就搞好了,這樣就更加有效地節(jié)約了時間。</p>

79、;<p>  這次課程設(shè)計不但讓我學(xué)得了一些編程知識,還學(xué)會了系統(tǒng)的做一份課程設(shè)計報告,學(xué)會了如何截圖,學(xué)會了如何更好的畫流程圖,明白了做事情只有認真,才能真正做得更好!</p><p>  這段時間里,我可是嘗到了所謂的酸甜苦辣。時而,為了一個錯誤而焦頭爛額;時而,為了編程而熬夜;時而,連吃飯都是匆匆了事;但一旦程序運行成功,總會有成功的喜悅。</p><p>  通過這次

80、課程設(shè)計,我了解了自己的編程功底和動手能力,但我并沒有灰心而喪失斗志。我想,在即將到來的的假期里,我會好好努力嘗試編寫一些程序.</p><p>  在這個程序中,還有許多地方值得完善。比如,,由于時間問題,暫時不能實現(xiàn)了。我想在有時間的情況下我會好好研究這個問題的。</p><p><b>  第九章.參考文獻</b></p><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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論