數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告 (3)_第1頁
已閱讀1頁,還剩21頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p>  《數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)》</p><p><b>  報(bào)告書</b></p><p>  2012/2013 第1學(xué)期</p><p>  專業(yè)班級(jí):_________</p><p>  學(xué) 號(hào):_________</p><p>  學(xué)生姓名:_________&l

2、t;/p><p><b>  計(jì)算機(jī)信息工程學(xué)院</b></p><p><b>  一.課程認(rèn)識(shí)</b></p><p>  數(shù)據(jù)結(jié)構(gòu)課程主要是研究非數(shù)值計(jì)算的程序設(shè)計(jì)問題中所出現(xiàn)的計(jì)算機(jī)操作對(duì)象以及它們之間的關(guān)系和操作的學(xué)科。數(shù)據(jù)結(jié)構(gòu)是介于數(shù)學(xué)、計(jì)算機(jī)軟件和計(jì)算機(jī)硬件之間的一門計(jì)算機(jī)專業(yè)的核心課程,它是計(jì)算機(jī)程序設(shè)計(jì)、數(shù)據(jù)

3、庫、操作系統(tǒng)、編譯原理及人工智能等的重要基礎(chǔ),廣泛的應(yīng)用于信息學(xué)、系統(tǒng)工程等各種領(lǐng)域。</p><p>  學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)是為了將實(shí)際問題中所涉及的對(duì)象在計(jì)算機(jī)中表示出來并對(duì)它們進(jìn)行處理。通過課程設(shè)計(jì)可以提高學(xué)生的思維能力,促進(jìn)學(xué)生的綜合應(yīng)用能力和專業(yè)素質(zhì)的提高。通過此次課程設(shè)計(jì)主要達(dá)到以下目的:</p><p>  了解并掌握數(shù)據(jù)結(jié)構(gòu)與算法的設(shè)計(jì)方法,具備初步的獨(dú)立分析和設(shè)計(jì)能力;<

4、/p><p>  初步掌握軟件開發(fā)過程的問題分析、系統(tǒng)設(shè)計(jì)、程序編碼、測(cè)試等基本方法和技能;</p><p>  提高綜合運(yùn)用所學(xué)的理論知識(shí)和方法獨(dú)立分析和解決問題的能力;</p><p>  訓(xùn)練用系統(tǒng)的觀點(diǎn)和軟件開發(fā)一般規(guī)范進(jìn)行軟件開發(fā),培養(yǎng)軟件工者所應(yīng)具備的科學(xué)的工作方法和作風(fēng)。</p><p><b>  二.課題選擇</

5、b></p><p><b>  1、內(nèi)部排序演示</b></p><p> ?。ㄒ唬﹩栴}描述及分析:</p><p>  設(shè)計(jì)一個(gè)測(cè)試程序比較幾種內(nèi)部排序算法的關(guān)鍵字比較次數(shù)和移動(dòng)次數(shù)以取得直觀感受。(1) 對(duì)起泡排序、直接排序、簡單選擇排序、快速排序、希爾排序、堆排序算法進(jìn)行比較;(2) 待排序的元素的關(guān)鍵字為整數(shù)。其中的數(shù)據(jù)要用

6、偽隨機(jī)產(chǎn)生程序產(chǎn)生(如10000個(gè)),至少</p><p>  用5組不同的輸入數(shù)據(jù)做比較,再使用各種算法對(duì)其進(jìn)行排序,記錄其排序時(shí)間,再匯總</p><p>  比較。(gettickcount())(二)數(shù)據(jù)結(jié)構(gòu)描述: </p><p>  本程序采用順序表結(jié)構(gòu),具體結(jié)構(gòu)定義如下:</p><p>  typedef struct &l

7、t;/p><p><b>  {</b></p><p>  ElemType *elem;</p><p>  int length;</p><p><b>  }SqList;</b></p><p> ?。ㄈ┲饕惴鞒堂枋觯?lt;/p><p>&

8、lt;b>  1.主要函數(shù)流程</b></p><p>  1.void addlist(SqList &L)//初始化順序表</p><p>  2.void random(SqList &L)//隨機(jī)數(shù)產(chǎn)生程序</p><p>  3. void memory(SqList &M,SqList &L)//記錄L,

9、使每個(gè)排序算法都用一組相同的隨機(jī)數(shù)</p><p>  4. void BubbleSort(SqList &L)//冒泡排序</p><p>  5. void InsertSort(SqList &L)//直接插入排序</p><p>  6. void SelectSort(SqList &L)//選擇排序</p><

10、;p>  7. int Partition(SqList &L,int low,int high)//快速排序</p><p>  8. void QSort(SqList &L,int low,int high)//對(duì)順序表的子序列作快速排序</p><p>  9. void ShellSort(SqList &L)//希爾排序</p>&

11、lt;p>  10. void HeapAdjust(SqList &L,int s,int m )//調(diào)整L.elem[s]的關(guān)鍵字,使L.elem[s…..m]成為一個(gè)大根堆</p><p>  11. void HeapSort(SqList &L)//對(duì)順序表L進(jìn)行堆排序</p><p>  12. void main()主函數(shù)</p><

12、p>  2. 主要代碼及程序說明</p><p>  #include"iostream"</p><p>  #include"stdio.h"</p><p>  #include"stdlib.h"</p><p>  #include"string.h&quo

13、t;</p><p>  #include"time.h"</p><p>  using namespace std;</p><p>  #define LIST_INIT_SIZE 50000</p><p>  int bj1=0,yd1=0,bj2=0,yd2=0,bj3=0,yd3=0,bj4=0,yd4=0,

14、bj5=0,yd5=0,bj6=0,yd6=0,n;//yd,bj為記錄關(guān)鍵字比較和移動(dòng)的次數(shù)</p><p>  typedef struct </p><p><b>  {</b></p><p><b>  int key; </b></p><p>  }ElemType;</p&g

15、t;<p>  typedef struct </p><p><b>  {</b></p><p>  ElemType *elem;</p><p>  int length;</p><p><b>  }SqList;</b></p><p>  vo

16、id addlist(SqList &L)//初始化順序表</p><p><b>  {</b></p><p>  a: printf("請(qǐng)輸入你要輸入的個(gè)數(shù):");</p><p>  scanf("%d",&n);</p><p>  if(n>500

17、00)</p><p><b>  {</b></p><p>  printf("超出范圍重新輸入!!!\n");</p><p><b>  goto a;</b></p><p><b>  }</b></p><p>  L.

18、elem=(ElemType*)malloc(LIST_INIT_SIZE*sizeof(ElemType));</p><p>  if(!L.elem)exit(0);</p><p><b>  }</b></p><p>  void random(SqList &L)//隨機(jī)數(shù)產(chǎn)生程序</p><p>

19、<b>  {</b></p><p>  L.length=0;</p><p>  static bool first=true;</p><p><b>  if(first)</b></p><p><b>  {</b></p><p>  s

20、rand(time(0));</p><p>  first=false;</p><p>  }//使輸入相同個(gè)數(shù)時(shí)每次產(chǎn)生的隨機(jī)數(shù)不同</p><p>  for(int i=1;i<n+1;i++)</p><p><b>  a: { </b></p><p>  L.elem[i

21、].key=rand();</p><p>  if(L.elem[i].key>30000)</p><p><b>  goto a;</b></p><p>  ++L.length;</p><p><b>  }</b></p><p><b>  

22、}</b></p><p>  void memory(SqList &M,SqList &L)//記錄L,使每個(gè)排序算法都用一組相同的隨機(jī)數(shù)</p><p><b>  { </b></p><p>  M.length=0;</p><p>  for(int i=1;i<n+1

23、;i++)</p><p>  {M.elem[i].key=L.elem[i].key;</p><p>  ++M.length;</p><p><b>  }</b></p><p><b>  }</b></p><p>  void BubbleSort(SqLi

24、st &L)//冒泡排序</p><p><b>  {</b></p><p><b>  int i,j;</b></p><p>  for(i=1;i<L.length;i++)</p><p>  {for(j=1;j<L.length-i+1;j++)</p&

25、gt;<p><b>  {bj1++;</b></p><p>  if(L.elem[j].key>L.elem[j+1].key)</p><p><b>  {</b></p><p>  L.elem[0].key=L.elem[j].key;</p><p>  L.

26、elem[j].key=L.elem[j+1].key;</p><p>  L.elem[j+1].key=L.elem[0].key;</p><p><b>  yd1+=3;</b></p><p><b>  }</b></p><p><b>  }</b><

27、/p><p><b>  }</b></p><p><b>  }</b></p><p>  void InsertSort(SqList &L)//直接插入排序</p><p><b>  {</b></p><p><b>  in

28、t i,j;</b></p><p>  for(i=2;i<=L.length;i++)</p><p><b>  {</b></p><p>  if(L.elem[i].key<L.elem[i-1].key)</p><p><b>  {</b></p>

29、;<p>  L.elem[0].key=L.elem[i].key;</p><p><b>  yd2++;</b></p><p><b>  j=i-1;</b></p><p><b>  bj2++;</b></p><p>  while(L.ele

30、m[0].key<L.elem[j].key)</p><p><b>  {</b></p><p>  L.elem[j+1].key=L.elem[j].key;</p><p><b>  j--;</b></p><p><b>  yd2++;</b><

31、/p><p><b>  bj2++;</b></p><p><b>  }</b></p><p>  L.elem[j+1].key=L.elem[0].key;</p><p><b>  yd2++;</b></p><p><b>  

32、}</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  void SelectSort(SqList &L)//選擇排序</p><p><b>  {</b></p><p>

33、  int i,j,k;</p><p>  for(i=1;i<L.length;i++)</p><p><b>  {</b></p><p><b>  k=i;</b></p><p>  for(j=i+1;j<L.length;j++)</p><p&g

34、t;<b>  {</b></p><p><b>  bj3++;</b></p><p>  if(L.elem[j].key<L.elem[k].key)k=j;</p><p><b>  }</b></p><p><b>  if(i!=k)<

35、/b></p><p><b>  {</b></p><p>  L.elem[0].key=L.elem[i].key;</p><p>  L.elem[i].key=L.elem[k].key;</p><p>  L.elem[k].key=L.elem[0].key;</p><p&

36、gt;<b>  yd3+=3;</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  int Partition(SqList &L,int low,i

37、nt high)//快速排序 </p><p><b>  {</b></p><p>  int pivotkey;</p><p>  L.elem[0]=L.elem[low];</p><p><b>  yd4++;</b></p><p>  pivotkey=L

38、.elem[low].key;</p><p>  while (low<high) </p><p><b>  {</b></p><p><b>  yd4++;</b></p><p>  while(low<high&&L.elem[high].key>=

39、pivotkey)</p><p><b>  --high;</b></p><p>  L.elem[low]=L.elem[high];</p><p><b>  bj4++;</b></p><p><b>  yd4++;</b></p><p&

40、gt;  while (low<high&&L.elem[low].key<=pivotkey)</p><p><b>  ++low;</b></p><p>  L.elem[high]=L.elem[low];</p><p><b>  bj4++;</b></p>&l

41、t;p><b>  yd4++;</b></p><p><b>  }</b></p><p>  L.elem[low]=L.elem[0];</p><p><b>  yd4++;</b></p><p>  return low;</p><

42、p><b>  }</b></p><p>  void QSort(SqList &L,int low,int high)</p><p>  {//對(duì)順序表的子序列作快速排序 </p><p>  int pivotloc;</p><p>  if(low<high)</p>&

43、lt;p><b>  {</b></p><p>  pivotloc=Partition(L,low,high);</p><p>  QSort(L,low,pivotloc-1);</p><p>  QSort(L,pivotloc+1,high);</p><p><b>  }</b&g

44、t;</p><p><b>  }</b></p><p>  void QuickSort(SqList &L)</p><p>  {//對(duì)順序表L作快速排序</p><p>  QSort(L,1,L.length);</p><p><b>  }</b>&

45、lt;/p><p>  void ShellSort(SqList &L)//希爾排序</p><p><b>  {</b></p><p>  int i,d=L.length/2,j,w=0,k;</p><p>  while(w<d)</p><p><b>  {&

46、lt;/b></p><p><b>  w=1;</b></p><p>  for(i=w;i<L.length;i=i+d)</p><p><b>  {</b></p><p><b>  k=i;</b></p><p>  fo

47、r(j=i+d;j<L.length;j=j+d)</p><p><b>  {</b></p><p>  if(L.elem[i].key>L.elem[j].key)</p><p><b>  {</b></p><p><b>  k=j;</b><

48、;/p><p><b>  bj5++;</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  if(i!=k)</b></p><p><b>  {</b

49、></p><p>  L.elem[0].key=L.elem[i].key;</p><p>  L.elem[i].key=L.elem[k].key;</p><p>  L.elem[k].key=L.elem[0].key;</p><p><b>  yd5+=3;</b></p>&l

50、t;p><b>  }</b></p><p><b>  w++;</b></p><p><b>  }</b></p><p><b>  d=d/2;</b></p><p><b>  w=1;</b></p&g

51、t;<p><b>  }</b></p><p><b>  }</b></p><p>  void HeapAdjust(SqList &L,int s,int m )</p><p>  {//調(diào)整L.elem[s]的關(guān)鍵字,使L.elem[s…..m]成為一個(gè)大根堆</p>&

52、lt;p>  SqList rc;</p><p>  rc.elem=(ElemType*)malloc(LIST_INIT_SIZE*sizeof(ElemType));</p><p>  if(!rc.elem)exit(0);</p><p><b>  int j;</b></p><p>  rc.e

53、lem[0]=L.elem[s];</p><p>  for(j=2*s;j<=m;j*=2)</p><p><b>  {bj6++;</b></p><p>  if(j<m&&L.elem[j].key<L.elem[j+1].key)</p><p><b>  +

54、+j;</b></p><p><b>  bj6++;</b></p><p>  if(!(rc.elem[0].key<L.elem[j].key)) break;</p><p>  L.elem[s]=L.elem[j];</p><p><b>  s=j;</b>&l

55、t;/p><p><b>  yd6+=3;</b></p><p><b>  }</b></p><p>  L.elem[s]=rc.elem[0];</p><p><b>  }</b></p><p>  void HeapSort(SqList

56、 &L)</p><p>  {//對(duì)順序表L進(jìn)行堆排序</p><p><b>  int i;</b></p><p>  for(i=L.length/2;i>0;--i)</p><p>  HeapAdjust(L,i,L.length);</p><p>  for(i=

57、L.length;i>1;--i)</p><p>  {L.elem[1]=L.elem[i];</p><p><b>  yd6+=3;</b></p><p>  HeapAdjust(L,1,i-1);</p><p><b>  }</b></p><p>

58、<b>  }</b></p><p>  void main()</p><p><b>  {</b></p><p>  SqList L,M;</p><p><b>  int a;</b></p><p>  M.elem=(ElemType

59、*)malloc(LIST_INIT_SIZE*sizeof(ElemType));</p><p>  if(!M.elem)exit(0);</p><p><b>  a:</b></p><p>  cout<<" ---------------------------------內(nèi)部排序算法比較---------

60、--------------------\n"; cout<<"************************************歡迎使用***********************************\n";</p><p>  cout<<"**********************************(1)運(yùn)行程序******

61、****************************\n";</p><p>  cout<<"**********************************(2)退出系統(tǒng)**********************************\n";</p><p>  cout<<endl;</p><p&

62、gt;  cout<<"請(qǐng)選擇:";</p><p>  scanf("%d",&a);</p><p><b>  switch(a)</b></p><p><b>  {</b></p><p>  case 1:system(&qu

63、ot;cls");addlist(L);break;</p><p>  case 2:cout<<"謝謝使用";exit(0);break;</p><p><b>  }</b></p><p>  random(L);</p><p>  memory(M,L);</

64、p><p>  BubbleSort(M);</p><p>  memory(M,L);</p><p>  InsertSort(M);</p><p>  memory(M,L);</p><p>  SelectSort(M);</p><p>  memory(M,L);</p>

65、;<p>  QuickSort(M);</p><p>  memory(M,L);</p><p>  ShellSort(M);</p><p>  memory(M,L);</p><p>  HeapSort(L);</p><p>  cout<<" **

66、*******比較次數(shù)**********移動(dòng)次數(shù)*********\n";</p><p>  cout<<"冒泡排序: "<<bj1<<" "<<yd1<<endl;</p><p>  cout<<"直接插入:

67、 "<<bj2<<" "<<yd2<<endl;</p><p>  cout<<"簡單選擇: "<<bj3<<" "<<yd3<<endl;</p><

68、;p>  cout<<"快速排序: "<<bj4<<" "<<yd4<<endl;</p><p>  cout<<"希爾排序: "<<bj5<<" "&

69、lt;<yd5<<endl;</p><p>  cout<<"堆排序 : "<<bj6<<" "<<yd6<<endl;</p><p>  cout<<endl;</p><p><b&g

70、t;  goto a;</b></p><p><b>  }</b></p><p><b> ?。ㄋ模┦褂谜f明:</b></p><p><b>  運(yùn)行程序:</b></p><p><b>  選擇1:</b></p>&

71、lt;p><b>  選擇10:</b></p><p>  選擇1,重復(fù)上述步驟,分別輸入100,200得到如下結(jié)果:</p><p><b>  輸入2,退出程序:</b></p><p>  結(jié)果分析:冒泡排序,直接插入排序以及簡單選擇排序比較次數(shù)較多,快速排序,希爾排序及堆排序比較次數(shù)較少;并可得冒泡排序和直

72、接插入排序相對(duì)較穩(wěn)定,其他四種內(nèi)部排序?yàn)椴环€(wěn)定排序。</p><p>  5、一元多項(xiàng)加法運(yùn)算的實(shí)現(xiàn)</p><p> ?。ㄒ唬﹩栴}描述及分析:</p><p>  設(shè)計(jì)一個(gè)程序,求解一元多項(xiàng)加法。如:A(x)=15+6x+9x7+3x18 B(x)=4x+5x6+16x7 求 A+B 。</p><p> ?。ǘ?shù)據(jù)結(jié)構(gòu)描述: &

73、lt;/p><p>  本程序采用鏈表結(jié)構(gòu),具體結(jié)構(gòu)定義如下:</p><p>  typedef struct polynode </p><p><b>  { </b></p><p>  int coef; //多項(xiàng)式的系數(shù) </p><p>  int exp; //指數(shù) </p>

74、;<p>  struct polynode *next; </p><p><b>  }node;</b></p><p>  (三)主要算法流程描述:</p><p><b>  1.主要函數(shù)流程</b></p><p>  1. node *create() //用尾插法建立一

75、元多項(xiàng)式的鏈表</p><p>  2. void print(node *p) //輸出函數(shù),打印出一元多項(xiàng)式</p><p>  3. void polyadd(node *ha, node *hb)//一元多項(xiàng)式相加函數(shù),用于將兩個(gè)多項(xiàng)式相加,然后將和多項(xiàng)式存放在多項(xiàng)式ha中,并將多項(xiàng)式hb刪除</p><p>  4. void main()主函數(shù)</

76、p><p>  2. 主要代碼及程序說明</p><p>  #include<stdio.h> </p><p>  #include<malloc.h> </p><p>  #include<stdlib.h> </p><p>  typedef struct polynode

77、</p><p><b>  { </b></p><p>  int coef; //多項(xiàng)式的系數(shù) </p><p>  int exp; //指數(shù) </p><p>  struct polynode *next; </p><p><b>  }node; </b>&l

78、t;/p><p>  node *create() //用尾插法建立一元多項(xiàng)式的鏈表 </p><p><b>  { </b></p><p>  node *h,*r,*s; </p><p><b>  int c,e; </b></p><p>  h=(node*)ma

79、lloc(sizeof(node)); </p><p><b>  r=h; </b></p><p>  printf("coef:"); </p><p>  scanf("%d",&c); </p><p>  printf("exp: ");

80、</p><p>  scanf("%d",&e); </p><p>  while(c!=0) //輸入系數(shù)為0時(shí),多項(xiàng)式的輸入結(jié)束 </p><p><b>  { </b></p><p>  s=(node*)malloc(sizeof(node)); </p><

81、;p>  s->coef=c; </p><p>  s->exp=e; </p><p>  r->next=s; </p><p><b>  r=s; </b></p><p>  printf("coef:"); </p><p>  scanf

82、("%d",&c); </p><p>  printf("exp: "); </p><p>  scanf("%d",&e); </p><p><b>  } </b></p><p>  r->next=NULL; </p&g

83、t;<p>  return(h); </p><p><b>  } </b></p><p>  void print(node *p) //輸出函數(shù),打印出一元多項(xiàng)式 </p><p><b>  { </b></p><p>  while(p->next!=NULL)

84、</p><p><b>  { </b></p><p>  p=p->next; </p><p>  printf(" %d*x^%d",p->coef,p->exp); </p><p><b>  } </b></p><p>

85、<b>  } </b></p><p>  void polyadd(node *ha, node *hb)//一元多項(xiàng)式相加函數(shù),用于將兩個(gè)多項(xiàng)式相加,然后將和多項(xiàng)式存放在多項(xiàng)式ha中,并將多項(xiàng)式hb刪除 </p><p><b>  { </b></p><p>  node *p,*q,*pre,*temp; &l

86、t;/p><p><b>  int sum; </b></p><p>  p=ha->next; </p><p>  q=hb->next; </p><p><b>  pre=ha; </b></p><p>  while(p!=NULL&&

87、;q!=NULL) </p><p><b>  { </b></p><p>  if(p->exp<q->exp) </p><p><b>  { </b></p><p>  pre->next=p; </p><p>  pre=pre-&g

88、t;next; </p><p>  p=p->next; </p><p><b>  } </b></p><p>  else if(p->exp==q->exp) </p><p><b>  { </b></p><p>  sum=p->c

89、oef+q->coef; </p><p>  if(sum!=0) </p><p><b>  { </b></p><p>  p->coef=sum; </p><p>  pre->next=p;pre=pre->next;p=p->next; </p><p&

90、gt;  temp=q;q=q->next;free(temp); </p><p><b>  } </b></p><p>  else //如果系數(shù)和為零,則刪除結(jié)點(diǎn)p與q,并將指針指向下一個(gè)結(jié)點(diǎn) </p><p><b>  { </b></p><p>  temp=p->ne

91、xt;free(p);p=temp; </p><p>  temp=q->next;free(q);q=temp; </p><p><b>  } </b></p><p><b>  } </b></p><p><b>  else </b></p>

92、<p><b>  { </b></p><p>  pre->next=q; </p><p>  pre=pre->next; </p><p>  q=q->next; </p><p><b>  } </b></p><p><b

93、>  } </b></p><p>  if(p!=NULL) //將多項(xiàng)式A中剩余的結(jié)點(diǎn)加入到和多項(xiàng)式中 </p><p>  pre->next=p; </p><p><b>  else </b></p><p>  pre->next=q; </p><p>

94、;<b>  } </b></p><p>  void main() </p><p><b>  { </b></p><p>  node *ha,*hb; </p><p>  printf("請(qǐng)輸入多項(xiàng)式ha的系數(shù)與指數(shù):\n"); </p><p&

95、gt;  ha=create(); </p><p>  print(ha); </p><p>  printf("\n"); </p><p>  printf("請(qǐng)輸入多項(xiàng)式hb的系數(shù)與指數(shù):\n"); </p><p>  hb=create(); </p><p>  

96、print(hb); </p><p>  printf("\n"); </p><p>  printf("多項(xiàng)式的和是:\n"); </p><p>  polyadd(ha,hb); </p><p>  print(ha); </p><p>  printf("

97、;\n"); </p><p><b>  }</b></p><p><b> ?。ㄋ模┦褂谜f明:</b></p><p><b>  運(yùn)行程序:</b></p><p>  分別輸入多項(xiàng)式ha的系數(shù)和指數(shù),直到系數(shù)和指數(shù)都為0結(jié)束:</p><

98、p>  繼續(xù)輸入hb的系數(shù)和指數(shù),直到系數(shù)和指數(shù)都為0結(jié)束,于是輸出ha+hb該多項(xiàng)式的和::</p><p>  3. 二叉排序樹結(jié)點(diǎn)的插入、刪除算法的實(shí)現(xiàn)</p><p> ?。ㄒ唬﹩栴}描述及分析:</p><p>  設(shè)計(jì)一個(gè)程序,插入和刪除二叉排序樹中給定的結(jié)點(diǎn),要求插入和刪除后仍然保持</p><p><b>  它

99、的有序性。</b></p><p> ?。ǘ?shù)據(jù)結(jié)構(gòu)描述: </p><p>  struct node</p><p><b>  {</b></p><p><b>  int data;</b></p><p>  struct node*lchild,*

100、rchild;</p><p><b>  };</b></p><p>  (三)主要算法流程描述:</p><p><b>  1.主要函數(shù)流程</b></p><p>  1. struct node *searchnode(int w,struct node *r)</p>&

101、lt;p>  2. struct node*insert(int w,struct node*p)</p><p>  3. struct node*father(struct node *p,struct node *r)</p><p>  4. struct node *dele(struct node *p,struct node *r)</p><p&g

102、t;  5. void printf(struct node *p)</p><p>  6. struct node*creat()創(chuàng)建二叉排序樹</p><p>  7. struct node*insertnode(struct node*root)插入結(jié)點(diǎn)</p><p>  8. struct node *delenode(struct node *roo

103、t)刪除結(jié)點(diǎn)</p><p>  9. void main()主函數(shù)</p><p>  2. 主要代碼及程序說明</p><p>  #include"stdio.h"</p><p>  #include"string.h"</p><p>  #include"m

104、alloc.h"</p><p>  struct node</p><p><b>  {</b></p><p><b>  int data;</b></p><p>  struct node*lchild,*rchild;</p><p><b>

105、;  };</b></p><p>  struct node *searchnode(int w,struct node *r)</p><p><b>  {</b></p><p>  struct node *p;</p><p>  if(r==NULL)</p><p>&

106、lt;b>  p=NULL;</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  if(w==r->data)</p><p><b>  p=r;</b></p><p&

107、gt;  else if(w>r->data)</p><p>  p=searchnode(w,r->rchild);</p><p><b>  else</b></p><p>  p=searchnode(w,r->lchild);</p><p><b>  }</b&g

108、t;</p><p>  return(p);</p><p><b>  }</b></p><p>  struct node*insert(int w,struct node*p)</p><p><b>  {</b></p><p>  if(p==NULL)<

109、;/p><p><b>  {</b></p><p>  p=(struct node*)malloc(sizeof(struct node));</p><p>  p->lchild=NULL;p->rchild=NULL;p->data=w;</p><p><b>  }</b&g

110、t;</p><p>  else if(w>p->data) //大于欲插入值進(jìn)行右子樹比較和插入</p><p>  p->rchild=insert(w,p->rchild);</p><p>  else //小于欲插入值

111、進(jìn)行左子樹比較和插入</p><p>  p->lchild=insert(w,p->lchild);</p><p>  return(p); //返回根節(jié)點(diǎn)</p><p><b>  }</b></p><p>  struct node*father(struct node *p,struct nod

112、e *r)</p><p><b>  {</b></p><p>  struct node *p3;</p><p>  if(r==NULL||p==r)</p><p><b>  p3=NULL;</b></p><p><b>  else </b

113、></p><p><b>  {</b></p><p>  if(p==r->lchild||p==r->rchild)</p><p><b>  p3=r;</b></p><p>  else if(p->data>r->data) </p>

114、<p>  p3=father(p,r->rchild);</p><p>  else p3=father(p,r->lchild);</p><p><b>  }</b></p><p>  return(p3);</p><p><b>  }</b></p&

115、gt;<p>  struct node *dele(struct node *p,struct node *r)</p><p><b>  {</b></p><p>  struct node*p1,*p2,*p3;</p><p>  p3=father(p,r);</p><p>  if(p-&

116、gt;lchild==NULL&&p->rchild==NULL&&p3!=NULL) //被刪節(jié)點(diǎn)是非根節(jié)點(diǎn)的葉子節(jié)點(diǎn)</p><p>  if(p3->lchild==p)</p><p>  p3->lchild=NULL;</p><p><b>  else</b></p&

117、gt;<p>  p3->rchild=NULL; //相應(yīng)的父親節(jié)點(diǎn)的孩子指針置為空</p><p>  if(p->lchild==NULL&&p->rchild==NULL&&p3==NULL)</p><p>  r=NULL;

118、 //</p><p>  if(p->lchild!=NULL&&p->rchild==NULL&&p3==NULL) //</p><p>  r=p->lchild;</p><p>  if(p->lchild==NULL&&p->rchild

119、!=NULL&&p3==NULL) //</p><p>  r=p->rchild;</p><p>  if(p->lchild==NULL&&p->rchild!=NULL&&p3!=NULL)</p><p>  if(p3->lchild==p)</p><

120、;p>  p3->lchild=p->rchild;</p><p><b>  else</b></p><p>  p3->rchild=p->rchild;</p><p>  if(p->lchild!=NULL&&p->rchild==NULL&&p3!=NUL

121、L)</p><p>  if(p3->lchild==p)</p><p>  p3->lchild=p->lchild;</p><p><b>  else</b></p><p>  p3->rchild=p->lchild;</p><p>  if(p-&

122、gt;lchild!=NULL&&p->rchild!=NULL)</p><p><b>  {</b></p><p>  p1=p->lchild;p3=p;</p><p>  while(p1->rchild!=NULL)</p><p><b>  {</b&

123、gt;</p><p><b>  p3=p1;</b></p><p>  p1=p1->rchild;</p><p><b>  }</b></p><p>  p->data=p1->data;</p><p>  if(p3!=p)

124、 //p的左孩子有右節(jié)點(diǎn)時(shí)操作</p><p>  p3->rchild=p1->lchild;</p><p><b>  else</b></p><p>  p3->lchild=p1->lchild;</p><p><b>  }</b></p>&l

125、t;p>  printf("\n");</p><p>  if(r==NULL)</p><p>  printf("sorry this tree is empty!");</p><p>  return(r);</p><p><b>  }</b></p>

126、;<p>  void printf(struct node *p)</p><p><b>  {</b></p><p>  if(p!=NULL)</p><p><b>  {</b></p><p>  printf(p->lchild);</p><

127、;p>  printf("%d ",p->data);</p><p>  printf(p->rchild);</p><p><b>  }</b></p><p><b>  }</b></p><p>  struct node*creat()</

128、p><p><b>  {</b></p><p>  struct node*root,*p;</p><p>  int s,t=0;</p><p>  root=NULL;</p><p>  printf("if you enter 0,tree is created!"

129、);</p><p><b>  do</b></p><p><b>  {</b></p><p>  printf("\n");</p><p>  printf("please enter data");</p><p>  s

130、canf("%d",&s);</p><p><b>  if(s==0)</b></p><p><b>  t=1;</b></p><p><b>  else</b></p><p><b>  {</b></p&

131、gt;<p>  p=searchnode(s,root);</p><p>  if(p==NULL)</p><p>  root=insert(s,root);</p><p>  else printf("the data exist,don't insert!\n");</p><p>&l

132、t;b>  }</b></p><p>  }while(!t);</p><p>  return(root);</p><p><b>  }</b></p><p>  struct node*insertnode(struct node*root)</p><p><

133、;b>  {</b></p><p><b>  int s;</b></p><p>  struct node*p;</p><p>  printf("\n");</p><p>  printf("please enter data");</p>

134、;<p>  scanf("%d",&s);</p><p><b>  if(s!=0)</b></p><p><b>  {</b></p><p>  p=searchnode(s,root);</p><p>  if(p==NULL)</p

135、><p>  root=insert(s,root);</p><p><b>  else</b></p><p>  printf("the data exist,don't insert again!\n");</p><p><b>  }</b></p>

136、<p>  return(root);</p><p><b>  }</b></p><p>  struct node *delenode(struct node *root)</p><p><b>  {</b></p><p><b>  int s;</b&

137、gt;</p><p>  struct node*p;</p><p><b>  char ch;</b></p><p>  printf("please enter the deleting node'value:");</p><p>  scanf("%d",&

138、amp;s);</p><p><b>  if(s!=-1)</b></p><p><b>  {</b></p><p>  p=searchnode(s,root);</p><p>  if(p==NULL)</p><p>  printf("sorry

139、 the data don't exist!");</p><p><b>  else</b></p><p><b>  {</b></p><p>  printf("the node exist ,delete?(Y/N)");</p><p>  ge

140、tchar();</p><p>  scanf("%c",&ch);</p><p>  if((ch=='y')||(ch=='Y'))</p><p>  root=dele(p,root);</p><p><b>  }</b></p>

141、<p><b>  }</b></p><p>  return(root);</p><p><b>  }</b></p><p>  void main()</p><p><b>  {</b></p><p>  struct nod

142、e*root;</p><p>  int c,t=1;</p><p>  printf("1:creat sort tree\n");</p><p>  printf("2:delete sort tree\n");</p><p>  printf("3:insert sort tre

143、e\n");</p><p>  printf("4:printf sort tree\n");</p><p><b>  while(t)</b></p><p><b>  {</b></p><p>  printf("please enter you

144、r choice:");</p><p>  scanf("%d",&c);</p><p><b>  switch(c)</b></p><p><b>  {</b></p><p>  case 1:root=creat();break;</p&g

145、t;<p>  case 2:root=delenode(root);break;</p><p>  case 3:root=insertnode(root);break;</p><p>  case 4:printf(root);break;</p><p>  default:break;</p><p><b&g

146、t;  }</b></p><p>  printf("continue:>0?");</p><p>  scanf("%d",&t);</p><p><b>  }</b></p><p><b>  }</b></p&g

147、t;<p><b>  (四)使用說明:</b></p><p><b>  運(yùn)行程序:</b></p><p><b>  輸入1:</b></p><p>  輸入一串?dāng)?shù)據(jù),到0結(jié)束:</p><p>  繼續(xù)程序,刪除結(jié)點(diǎn)2:</p><

148、p>  輸入4,輸出二叉排序樹排序好的數(shù)據(jù):</p><p><b>  三、總結(jié)</b></p><p>  一周的課程設(shè)計(jì)結(jié)束了,在這次的課程設(shè)計(jì)中不僅檢驗(yàn)了我所學(xué)習(xí)的知識(shí),也培養(yǎng)了我如何去把握一件事情,如何去做一件事情,又如何完成一件事情的方法和技巧,心里有一種成就感。這次課程設(shè)計(jì),我學(xué)到了很多東西:學(xué)會(huì)了在編寫幾百行程序時(shí)如何查找錯(cuò)誤,如何改錯(cuò)誤;了解數(shù)

149、據(jù)結(jié)構(gòu)在編寫比較復(fù)雜的程序的重要作用鞏固和加深了對(duì)數(shù)據(jù)結(jié)構(gòu)的理解,提高綜合運(yùn)用本課程所學(xué)知識(shí)的能力。培養(yǎng)了我選用參考書,查閱手冊(cè)及文獻(xiàn)資料的能力。培養(yǎng)獨(dú)立思考,深入研究,分析問題、解決問題的能力。通過實(shí)際編譯系統(tǒng)的分析設(shè)計(jì)、編程調(diào)試,掌握應(yīng)用軟件的分析方法和工程設(shè)計(jì)方法。夠按要求編寫課程設(shè)計(jì)報(bào)告書,能正確闡述設(shè)計(jì)和實(shí)驗(yàn)結(jié)果,正確繪制系統(tǒng)和程序框圖。通過課程設(shè)計(jì),培養(yǎng)了我嚴(yán)肅認(rèn)真的工作作風(fēng),逐步建立正確的生產(chǎn)觀念、經(jīng)濟(jì)觀念和全局觀念。同時(shí)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論