數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-二叉排序樹的簡單應(yīng)用報(bào)告_第1頁
已閱讀1頁,還剩14頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p><b>  數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</b></p><p><b>  設(shè)計(jì)說明書</b></p><p>  起止日期:2012 年 12 月 22 日 至 2013 年 01 月 02日</p><p>  年 月 日</p><p><b>  目

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

3、t;<p><b>  五、數(shù)據(jù)結(jié)構(gòu)2</b></p><p><b>  六、源程序2</b></p><p><b>  七、測試情況7</b></p><p>  八、設(shè)計(jì)體會及今后的改進(jìn)意見8</p><p><b>  參 考 文 獻(xiàn)

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

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

6、3,12,37,93)</p><p> ?。?)關(guān)鍵字序列為(44,10,50,3,33,100,22,61,90,78)</p><p><b>  三、算法思想</b></p><p>  因?yàn)槎媾判驑涞牟僮饕鶕?jù)結(jié)點(diǎn)的關(guān)鍵字域來進(jìn)行,所以,首先要定義每個結(jié)點(diǎn)的數(shù)據(jù)域類型。二叉排序樹的遍歷算法和二叉樹類似,利用鏈表存儲二叉樹,用隊(duì)列實(shí)現(xiàn)

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

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

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

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

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

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

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

14、t;p>  int key; //關(guān)鍵字項(xiàng)</p><p>  }ElemType;</p><p>  typedef struct BSTNode{</p><p>  ElemType data;//每個結(jié)點(diǎn)數(shù)據(jù)域包括關(guān)鍵字項(xiàng)和其他數(shù)據(jù)項(xiàng)</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 //最大隊(duì)列長度</p><p>  typedef struct ElemType{</p><p><b>  int key;</b></p>

18、;<p>  }ElemType;</p><p>  typedef struct BSTNode{</p><p>  ElemType data;//結(jié)點(diǎn)數(shù)據(jù)域</p><p>  struct BSTNode *lchild,*rchild;//左右孩子指針</p><p>  }BSTNode,*BSTree;&l

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

20、t;p>  int rear; //隊(duì)尾指針</p><p>  }SqQueue; //順序隊(duì)列的類型名</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;  //隊(duì)列的基本操作</b></p><p>  Status InitQueue(SqQueue &Q) //隊(duì)列的初始化</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) //入隊(duì)函數(shù)</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) //出隊(duì)函數(shù)</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) //判???lt;/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>  //當(dāng)二叉排序樹T中不存在關(guān)鍵字等于e.key的數(shù)據(jù)元素時,則插入該元素</p><p>  if(!T) { //找到插入位置,遞歸結(jié)束</p><p>  BSTree S = new BSTNode;

34、 //生成新結(jié)點(diǎn)*S</p><p>  S->data = e; //新結(jié)點(diǎn)*S的數(shù)據(jù)域置為e </p><p>  S->lchild = S->rchild = NULL;//新結(jié)點(diǎn)*S作為葉子結(jié)點(diǎn)</p><p>  T =S; //把新結(jié)點(diǎn)*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、;  //依次讀入一個關(guān)鍵字為key的結(jié)點(diǎn),將此結(jié)點(diǎn)插入二叉排序樹T中</p><p><b>  T=NULL;</b></p><p>  ElemType e;</p><p>  cin>>e.key; //???</p><p>  while(e.key!='\0')

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

39、t;p>  void lev_traverse(BSTree T) /* 用隊(duì)列實(shí)現(xiàn)層次遍歷 */</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>  { /* 當(dāng)隊(duì)列不空 */</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 非空根指針進(jìn)棧,遍歷左子樹</p><p>  p=p->lchild;} </p><p><b>  else</b></p><p>  { Po

51、p(S,q); //p 為空根指針退棧,訪問根結(jié)點(diǎn),遍歷右子樹</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) //求二叉樹的葉子數(shù)</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; //完成函數(shù)后請刪除此行</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結(jié)束輸入"<<endl;</p><p>  CreateBST(T);</p><p>  cout<<"當(dāng)前有序二叉樹層次遍歷結(jié)果為: \n";</p><p>  lev_traverse(T);cout<<"\n"

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

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

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

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

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

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

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

溫馨提示

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

最新文檔

評論

0/150

提交評論