數據結構課程設計-二叉排序樹的簡單應用報告_第1頁
已閱讀1頁,還剩14頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  數據結構課程設計</b></p><p><b>  設計說明書</b></p><p>  起止日期:2012 年 12 月 22 日 至 2013 年 01 月 02日</p><p>  年 月 日</p><p><b>  目

2、 錄</b></p><p><b>  一、問題描述1</b></p><p><b>  二、測試數據1</b></p><p><b>  三、算法思想1</b></p><p><b>  四、模塊劃分1</b></p&g

3、t;<p><b>  五、數據結構2</b></p><p><b>  六、源程序2</b></p><p><b>  七、測試情況7</b></p><p>  八、設計體會及今后的改進意見8</p><p><b>  參 考 文 獻

4、9</b></p><p><b>  一、問題描述</b></p><p><b>  1)具體問題描述</b></p><p>  輸入樹的各個結點,建立排序二叉樹,對建立的排序二叉樹進行層次、先序、中序和后序遍歷并統(tǒng)計該二叉樹中葉子結點的數目等。 </p><p><b>

5、;  2)基本要求</b></p><p><b>  (1)用菜單實現</b></p><p>  (2)能夠輸入樹的各個結點,并能夠輸出用不同方法遍歷的遍歷序列和葉子結點的數目。</p><p><b>  二、測試數據</b></p><p> ?。?)關鍵字序列為(45,24,5

6、3,12,37,93)</p><p> ?。?)關鍵字序列為(44,10,50,3,33,100,22,61,90,78)</p><p><b>  三、算法思想</b></p><p>  因為二叉排序樹的操作要根據結點的關鍵字域來進行,所以,首先要定義每個結點的數據域類型。二叉排序樹的遍歷算法和二叉樹類似,利用鏈表存儲二叉樹,用隊列實現

7、層次遍歷,利用棧進行非遞歸中序遍歷二叉樹,所以在創(chuàng)建二叉排序樹之前,定義二叉鏈表的存儲表示,對隊列、棧進行定義 。</p><p>  二叉排序樹的創(chuàng)建是從空的二叉排序樹開始,每輸入一個結點,經過查找操作(二叉排序樹插入的基本過程是查找),,將新的結點插入到當前二叉排序樹的合適位置。首先將二叉排序樹T初始化為空樹,讀入一個關鍵字為key的結點,將此結點插入到二叉排序樹T中,重復執(zhí)行,直至讀入的關鍵字key是輸入結

8、束標志。</p><p>  根據開始定義好的隊列的定義、操作,用隊列實現層次遍歷;按先序次序輸入二叉樹中結點的值(一個字符),創(chuàng)建二叉鏈表表示的二叉樹T;分別輸入先序遍歷二叉樹T的遞歸算法、中序遍歷二叉樹T的遞歸算法、后序遍歷二叉樹T的遞歸算法;利用棧進行非遞歸中序遍歷二叉樹,非空根指針進棧,遍歷左子樹,為空根指針退棧,訪問根結點,遍歷右子樹;遞歸查找葉子數,左子樹的葉子數加上右葉子數,可以計算出二叉樹的葉子數

9、</p><p><b>  四、模塊劃分</b></p><p> ?。?)二叉排序樹的操作要根據結點的關鍵字域來進行,其中包括基本操作的函數有:用隊列實現層次遍歷操作函數、先序遍歷有序二叉樹T的遞歸算法、中序遍歷有序二叉樹T的遞歸算法、后序遍歷有序二叉樹T的遞歸算法、用棧實現非遞歸中序遍歷有序二叉樹T的算法、求有序二叉樹的葉子數,該抽象數據類型文件名為BSTree

10、.h。</p><p>  (2)void InsertBST(BSTree &T,ElemType e ),其功能是向二叉樹插入新的結點。</p><p> ?。?)void CreateBST(BSTree &T ),其功能是創(chuàng)建有序二叉樹。</p><p> ?。?)void lev_traverse(BSTree T),其功能是用隊列實現有序

11、二叉樹的層次遍歷。</p><p>  (5)void PreOrderTraverse(BSTree T),其功能是實現有序二叉樹T的遞歸先序遍歷。</p><p> ?。?)void InOrderTraverse(BSTree &T),其功能是實現有序二叉樹T的遞歸中序遍歷。</p><p> ?。?)void PostOrderTraverse(BS

12、Tree T),其功能是實現有序二叉樹T的遞歸后序遍歷。</p><p>  (8)void InOrderTraverses(BSTree T),其功能是實現有序二叉樹T的非遞歸中序遍歷。</p><p>  (9)int leaf(BSTree T),其功能是求有序二叉樹的葉子數。</p><p> ?。?0)void main(),主函數,其功能是建立二叉排序

13、樹,調用以上函數對建立的排序二叉樹進行層次、先序、中序和后序遍歷并統(tǒng)計該二叉樹中葉子結點的數目。</p><p><b>  五、數據結構</b></p><p> ?。?)二叉排序樹的操作里每個結點的數據域的類型定義(包括關鍵字項和其他數據項)</p><p>  typedef struct ElemType{</p>&l

14、t;p>  int key; //關鍵字項</p><p>  }ElemType;</p><p>  typedef struct BSTNode{</p><p>  ElemType data;//每個結點數據域包括關鍵字項和其他數據項</p><p>  struct BSTNode *lchild,*rchild;

15、//左右孩子指針</p><p>  }BSTNode,*BSTree;</p><p><b>  六、源程序</b></p><p>  源程序存放在文件BSTree.h中</p><p>  文件BSTree.h:</p><p>  #include<iostream><

16、/p><p>  using namespace std;</p><p>  typedef int Status;</p><p>  #define OVERFLOW -2</p><p>  #define OK 1</p><p>  #define TRUE 1 </p><p>  

17、#define FALSE 0 </p><p>  #define ERROR 0</p><p>  #define MAXQSIZE 100 //最大隊列長度</p><p>  typedef struct ElemType{</p><p><b>  int key;</b></p>

18、;<p>  }ElemType;</p><p>  typedef struct BSTNode{</p><p>  ElemType data;//結點數據域</p><p>  struct BSTNode *lchild,*rchild;//左右孩子指針</p><p>  }BSTNode,*BSTree;&l

19、t;/p><p><b>  //隊列定義</b></p><p>  typedef struct{ </p><p>  BSTree *base; //初始化的動態(tài)分配存儲空間的基礎 </p><p>  int front; //隊頭指針</p>&l

20、t;p>  int rear; //隊尾指針</p><p>  }SqQueue; //順序隊列的類型名</p><p><b>  //棧的定義</b></p><p>  typedef struct </p>

21、<p><b>  { </b></p><p>  BSTree *base;</p><p>  BSTree *top;</p><p>  int stacksize;</p><p><b>  }SqStack;</b></p><p><b&

22、gt;  //隊列的基本操作</b></p><p>  Status InitQueue(SqQueue &Q) //隊列的初始化</p><p><b>  {</b></p><p>  Q.base=new BSTree[MAXQSIZE];</p><p>  if(!Q.base) ex

23、it(OVERFLOW);</p><p>  Q.front=Q.rear=0;</p><p>  return OK;</p><p><b>  }</b></p><p>  Status EnQueue(SqQueue &Q,BSTree p) //入隊函數</p><p>&

24、lt;b>  {</b></p><p>  if((Q.rear+1)%MAXQSIZE==Q.front) return ERROR;</p><p>  Q.base[Q.rear]=p;</p><p>  Q.rear=(Q.rear+1)%MAXQSIZE;</p><p>  return OK;</

25、p><p><b>  }</b></p><p>  Status DeQueue(SqQueue &Q,BSTree &p) //出隊函數</p><p><b>  {</b></p><p>  if(Q.front==Q.rear) return ERROR;</p&

26、gt;<p>  p=Q.base[Q.front];</p><p>  Q.front=(Q.front+1)%MAXQSIZE;</p><p>  return OK;</p><p><b>  }</b></p><p><b>  //棧的基本操作</b></p&g

27、t;<p>  Status InitStack(SqStack &S) //棧的初始化</p><p><b>  {</b></p><p>  S.base=new BSTree[MAXQSIZE];</p><p>  if(!S.base) exit(OVERFLOW);</p><p&g

28、t;  S.top=S.base;</p><p>  S.stacksize=MAXQSIZE;</p><p>  return OK;</p><p><b>  }</b></p><p>  Status Push(SqStack &S, BSTree P) //入棧</p><

29、;p><b>  { </b></p><p>  if (S.top-S.base==S.stacksize) return ERROR;</p><p>  *S.top++=P;</p><p>  return OK;</p><p><b>  }</b></p>&

30、lt;p>  Status Pop(SqStack &S , BSTree &q) //出棧</p><p><b>  { </b></p><p>  if (S.top==S.base) </p><p>  return ERROR;</p><p>  q=*--S.top;<

31、;/p><p>  return OK;</p><p><b>  }</b></p><p>  Status StackEmpty(SqStack &S) //判棧空</p><p><b>  { </b></p><p>  if(S.top==S.b

32、ase) </p><p>  return TRUE;</p><p><b>  else</b></p><p>  return FALSE;</p><p><b>  }</b></p><p>  // 二叉排序樹的插入</p><p&g

33、t;  void InsertBST(BSTree &T,ElemType e ) {</p><p>  //當二叉排序樹T中不存在關鍵字等于e.key的數據元素時,則插入該元素</p><p>  if(!T) { //找到插入位置,遞歸結束</p><p>  BSTree S = new BSTNode;

34、 //生成新結點*S</p><p>  S->data = e; //新結點*S的數據域置為e </p><p>  S->lchild = S->rchild = NULL;//新結點*S作為葉子結點</p><p>  T =S; //把新結點*S鏈接

35、到已找到的插入位置</p><p><b>  }</b></p><p>  else if (e.key< T->data.key) </p><p>  InsertBST(T->lchild, e );//將*S插入左子樹</p><p>  else if (e.key> T-&g

36、t;data.key) </p><p>  InsertBST(T->rchild, e);//將*S插入右子樹</p><p>  }// InsertBST</p><p>  // 二叉排序樹的創(chuàng)建</p><p>  void CreateBST(BSTree &T ) {</p><p>

37、;  //依次讀入一個關鍵字為key的結點,將此結點插入二叉排序樹T中</p><p><b>  T=NULL;</b></p><p>  ElemType e;</p><p>  cin>>e.key; //???</p><p>  while(e.key!='\0')

38、{ //0作為輸入結束標志</p><p>  InsertBST(T, e); //將此結點插入二叉排序樹T中</p><p>  cin>>e.key;//???</p><p>  }//while </p><p>  }//CreatBST</p>&l

39、t;p>  void lev_traverse(BSTree T) /* 用隊列實現層次遍歷 */</p><p><b>  { </b></p><p>  SqQueue q;</p><p>  BSTNode *p;</p><p>  InitQueue(q);</p>&l

40、t;p><b>  p=T;</b></p><p>  EnQueue(q,p);</p><p>  while(!(q.rear==q.front))</p><p>  { /* 當隊列不空 */</p><p>  DeQueue(q,p);</p><p>  printf(&q

41、uot;%d ",p->data);</p><p>  if(p->lchild!=NULL)</p><p>  EnQueue(q,p->lchild);</p><p>  if(p->rchild!=NULL)</p><p>  EnQueue(q,p->rchild);</p>

42、<p><b>  }</b></p><p><b>  }</b></p><p>  void PreOrderTraverse(BSTree T) //先序遍歷二叉樹T的遞歸算法</p><p><b>  { </b></p><p><b&

43、gt;  if(T)</b></p><p><b>  {</b></p><p>  cout << T-> data.key;</p><p>  PreOrderTraverse(T->lchild);</p><p>  PreOrderTraverse(T->rchi

44、ld);</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  //中序遞歸遍歷</b></p><p>  void InOrderTraverse(BSTree &T)</p><p>&

45、lt;b>  {</b></p><p><b>  if(T)</b></p><p><b>  {</b></p><p>  InOrderTraverse(T->lchild);</p><p>  cout<<T-> data.key;</

46、p><p>  InOrderTraverse(T->rchild);</p><p><b>  }</b></p><p><b>  }</b></p><p>  void PostOrderTraverse(BSTree T)//后序遍歷二叉樹T的遞歸算法</p><

47、p><b>  { </b></p><p><b>  if(T)</b></p><p><b>  {</b></p><p>  PostOrderTraverse(T->lchild);</p><p>  PostOrderTraverse(T->

48、;rchild);</p><p>  cout << T->data.key;</p><p><b>  }</b></p><p><b>  }</b></p><p>  void InOrderTraverses(BSTree T) //非遞歸中序遍歷二叉樹<

49、/p><p>  { SqStack S;</p><p><b>  BSTree p;</b></p><p>  BSTree q=new BSTNode;</p><p>  InitStack (S); p=T;</p><p>  while(p||!StackEmpty(S))<

50、;/p><p><b>  { if(p) </b></p><p>  {Push(S,p);// p 非空根指針進棧,遍歷左子樹</p><p>  p=p->lchild;} </p><p><b>  else</b></p><p>  { Po

51、p(S,q); //p 為空根指針退棧,訪問根結點,遍歷右子樹</p><p>  cout<<q->data.key;</p><p>  p=q->rchild;}</p><p><b>  }</b></p><p>  } // while</p><p>  

52、int leaf(BSTree T) //求二叉樹的葉子數</p><p>  {if (T==NULL) </p><p>  return 0;</p><p><b>  else </b></p><p>  { if (T->lchild==NULL&&T->rchild==

53、NULL) </p><p>  return 1;</p><p><b>  else</b></p><p>  return leaf(T->lchild)+leaf(T->rchild);</p><p><b>  }</b></p><p>  

54、return 0; //完成函數后請刪除此行</p><p><b>  }</b></p><p>  void main()</p><p><b>  {</b></p><p><b>  BSTree T;</b></p><p>  cou

55、t<<"請輸入若干字符,用回車區(qū)分,以0結束輸入"<<endl;</p><p>  CreateBST(T);</p><p>  cout<<"當前有序二叉樹層次遍歷結果為: \n";</p><p>  lev_traverse(T);cout<<"\n"

56、;;</p><p>  cout<<"當前有序二叉樹先序遍歷結果為: \n";</p><p>  PreOrderTraverse(T);cout<<"\n";</p><p>  cout<<"當前有序二叉樹遞歸中序遍歷結果為: \n";</p>&l

57、t;p>  InOrderTraverse(T);cout<<"\n";</p><p>  cout<<"當前有序二叉樹后序遍歷結果為: \n";</p><p>  PostOrderTraverse(T);cout<<"\n";</p><p>  cout&

58、lt;<"當前有序二叉樹非遞歸中序遍歷:\n";</p><p>  InOrderTraverses(T);cout<<"\n";</p><p>  cout<<"二叉樹的葉子數:"<<leaf(T);cout<<"\n";</p><

59、;p>  cout<<endl;</p><p><b>  }</b></p><p><b>  七、測試情況</b></p><p>  測試數據(1)關鍵字序列為(45,24,53,12,37,93)的程序輸出為:</p><p>  測試數據(2)關鍵字序列為(44,10

60、,50,3,33,100,22,61,90,78)</p><p><b>  的程序輸出為:</b></p><p>  經檢驗,得出輸出的結果是正確的。</p><p>  八、設計體會及今后的改進意見</p><p>  通過這次課程設計,我對數據結構中二叉排序樹及二叉樹的知識掌握地更加熟練,包括如何運用隊列實現二

61、叉排序樹的層次遍歷,利用棧進行非遞歸中序遍歷二叉排序樹,對二叉排序樹的先序遍歷、中序遍歷、后序遍歷方法了解得更加深入,掌握了二叉排序樹能實現的一些基本操作。</p><p>  此外,在熟悉課本知識的同時,學會自主學習課外知識,課外知識與課本的知識相結合,實現算法的補充、創(chuàng)新。遇到疑問時,老師、同學會熱心的幫我解答,備感溫暖。然而也認識到自己對數據結構課程的學習仍不夠深入,仍需進一步研究。另外也發(fā)現了自己的許多不

62、足之處:本程序設計僅能夠實現二叉排序樹的一些基本操作,算法比較簡單。若想用此程序解決生活中的實際問題,還需另外增加、修改一些程序,這個方面有待加強。在未來通過對數據結構更深入地學習,提高自己的能力,靈活運用所學知識解決生活中的實際問題。 </p><p><b>  參 考 文 獻</b></p><p>  [1]譚浩強,C語言程序設計.北京:清華大學出版社,200

溫馨提示

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

評論

0/150

提交評論