數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---二叉樹(shù)的操作_第1頁(yè)
已閱讀1頁(yè),還剩9頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、<p><b>  數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</b></p><p>  題 目: 二叉樹(shù)的操作 </p><p>  學(xué)生姓名: </p><p>  學(xué) 號(hào): </p><p>  系部名稱(chēng): 計(jì)算機(jī)科學(xué)與技術(shù)系</p><p

2、>  專(zhuān)業(yè)班級(jí): </p><p>  指導(dǎo)教師: </p><p> 課 程 設(shè) 計(jì) 任 務(wù) 書(shū)</p><p> 組內(nèi)學(xué)生姓名人數(shù)1</p><p> 系部名稱(chēng)計(jì)算機(jī)科學(xué)與技術(shù)系專(zhuān)業(yè)軟件工程班級(jí)、學(xué)號(hào)</p><p> 指導(dǎo)教師姓名職稱(chēng)從事專(zhuān)業(yè)軟件工程</p><p&g

3、t; 題目名稱(chēng)二叉樹(shù)的操作</p><p> 課程設(shè)計(jì)的目的、意義目的在于通過(guò)課程設(shè)計(jì)的綜合訓(xùn)練,幫助學(xué)生深入系統(tǒng)地掌握數(shù)據(jù)結(jié)構(gòu)課程的主要內(nèi)容和基本方法,培養(yǎng)學(xué)生綜合運(yùn)用所學(xué)知識(shí)分析解決實(shí)際問(wèn)題和編程等實(shí)際動(dòng)手能力。熟練的掌握二叉樹(shù)的基本操作。</p><p> 二、課程設(shè)計(jì)的主要內(nèi)容、技術(shù)要求(包括原始數(shù)據(jù)、技術(shù)參數(shù)、設(shè)計(jì)要求、工作量要求等)實(shí)現(xiàn)二叉樹(shù)的先序、中序和后序遍歷;求二叉樹(shù)的結(jié)

4、點(diǎn)總數(shù)、葉子結(jié)點(diǎn)個(gè)數(shù)及二叉樹(shù)的深度。</p><p> 三、課程設(shè)計(jì)完成后應(yīng)提交的成果完整的論文和部分源代碼</p><p> 四、課程設(shè)計(jì)的工作進(jìn)度安排(1)復(fù)習(xí)與設(shè)計(jì)題目相關(guān)的數(shù)據(jù)結(jié)構(gòu)知識(shí),查閱文獻(xiàn)資料 (1天)(2)確定設(shè)計(jì)方案,設(shè)計(jì)模塊結(jié)構(gòu)及各模塊流程 (1天)(3)編碼、調(diào)試與測(cè)試

5、 (5天)(4)撰寫(xiě)課程設(shè)計(jì)報(bào)告 (2天)(5)設(shè)計(jì)演示 (1天) </p><p> 五、主要參考資料1.嚴(yán)蔚敏、吳偉民,《數(shù)據(jù)結(jié)構(gòu)》(C語(yǔ)言版),北京:清華大學(xué)出版社,2006.52.寧正元、易金聰,《數(shù)據(jù)結(jié)構(gòu)習(xí)題解析與上機(jī)實(shí)驗(yàn)指導(dǎo)》,中國(guó)水利水電出版社、上海

6、交通大學(xué)出版社、東南大學(xué)出版社,2002.6</p><p> 六、備注</p><p> 指導(dǎo)教師簽字:年 月 日教研室主任簽字: 年 月 日</p><p><b>  程序要求</b></p><p>  1)完成二叉樹(shù)的基本操作。</p><p>  2)建

7、立以二叉鏈表為存儲(chǔ)結(jié)構(gòu)的二叉樹(shù);</p><p>  3)實(shí)現(xiàn)二叉樹(shù)的先序、中序和后序遍歷;</p><p>  4)求二叉樹(shù)的結(jié)點(diǎn)總數(shù)、葉子結(jié)點(diǎn)個(gè)數(shù)及二叉樹(shù)的深度。</p><p><b>  算法分析</b></p><p>  建立以二叉鏈表為存儲(chǔ)結(jié)構(gòu)的二叉樹(shù),在次二叉樹(shù)上進(jìn)行操作;</p><

8、p>  1先序遍歷二叉樹(shù)的操作定義為:</p><p>  若二叉樹(shù)唯恐則為空操作;否則</p><p><b>  (1)訪問(wèn)根節(jié)點(diǎn);</b></p><p> ?。?)先序遍歷做字?jǐn)?shù)和;</p><p> ?。?)先序遍歷有子樹(shù);</p><p>  2中序遍歷二叉樹(shù)的操作定義為:<

9、;/p><p>  若二叉樹(shù)為空,則空操作;否則 </p><p>  (1)中序遍歷做子樹(shù);</p><p><b> ?。?)訪問(wèn)根節(jié)點(diǎn);</b></p><p> ?。?)中序遍歷有子樹(shù);</p><p>  3后續(xù)遍歷二叉樹(shù)的操作定義為:</p><p>  若二叉樹(shù)為

10、空則為空操作;否則</p><p> ?。?)后序遍歷左子樹(shù) ;</p><p> ?。?)后序遍歷右子樹(shù);</p><p>  (3)訪問(wèn)根節(jié)點(diǎn) ; </p><p>  二叉樹(shù)的結(jié)點(diǎn)總數(shù)、葉子結(jié)點(diǎn)個(gè)數(shù)及二叉樹(shù)的深度。</p><p><b>  二叉樹(shù)的基本操作和</b></p>

11、<p>  算法實(shí)現(xiàn) </p><p>  二叉樹(shù)是一種重要的非線性數(shù)據(jù)結(jié)構(gòu),是另一種樹(shù)形結(jié)構(gòu),它的特點(diǎn)是每個(gè)節(jié)點(diǎn)之多有兩棵子樹(shù)(即二叉樹(shù)中不存在度大于2的結(jié)點(diǎn)),并且二叉樹(shù)的結(jié)點(diǎn)有左右之分,其次序不能隨便顛倒。</p><p><b>  二叉樹(shù)創(chuàng)建</b></p><p>  二叉樹(shù)的很多操作都是基于遍歷實(shí)現(xiàn)的。二叉

12、樹(shù)的遍歷是采用某種策略使得采用樹(shù)形結(jié)構(gòu)組織的若干年借點(diǎn)對(duì)應(yīng)于一個(gè)線性序列。二叉樹(shù)的遍歷策略有四種:先序遍歷 中續(xù)遍歷 后續(xù)遍歷和層次遍歷。</p><p><b>  基本要求</b></p><p>  1 從鍵盤(pán)接受輸入數(shù)據(jù)(先序),以二叉鏈表作為存儲(chǔ)結(jié)構(gòu),建立二叉樹(shù)。</p><p><b>  2 輸出二叉樹(shù)。</b&g

13、t;</p><p>  3 對(duì)二叉樹(shù)進(jìn)行遍歷(先序,中序,后序和層次遍歷)</p><p>  4 將二叉樹(shù)的遍歷打印出來(lái)。</p><p><b>  一.問(wèn)題描述</b></p><p>  二叉樹(shù)的很多操作都是基于遍歷實(shí)現(xiàn)的。二叉樹(shù)的遍歷是采用某種策略使得采用樹(shù)型結(jié)構(gòu)組織的若干結(jié)點(diǎn)對(duì)應(yīng)于一個(gè)線性序列。二叉樹(shù)的遍歷

14、策略有四種:先序遍歷、中序遍歷、后序遍歷和層次遍歷。</p><p><b>  二.基本要求</b></p><p>  1.從鍵盤(pán)接受輸入數(shù)據(jù)(先序),以二叉鏈表作為存儲(chǔ)結(jié)構(gòu),建立二叉樹(shù)。</p><p><b>  2.輸出二叉樹(shù)。</b></p><p>  3.對(duì)二叉樹(shù)進(jìn)行遍歷(先序、中序

15、、后序和層次遍歷)。</p><p>  4.將二叉樹(shù)的遍歷結(jié)果打印輸出。</p><p><b>  三.提示與分析</b></p><p><b>  1.主要數(shù)據(jù)類(lèi)型</b></p><p><b> ?、?二叉鏈表</b></p><p>  #

16、 define DataType char /*元素類(lèi)型*/</p><p>  typedef struct BiTNode</p><p>  {DataType data;</p><p>  struct BiTNode *lchild, *rchild;</p><p>  }BiTNode, *BiTree;</p>

17、<p>  ② 二叉樹(shù)的遍歷序列</p><p>  DataType preorder[n];</p><p>  DataType inorder[n];</p><p>  DataType postorder[n];</p><p><b>  2.基本功能分析</b></p><

18、;p>  ① 采用教材上類(lèi)似于先序遍歷的方法逐個(gè)輸入結(jié)點(diǎn),建立二叉鏈表存儲(chǔ)的二叉樹(shù)。</p><p>  ② 采用遞歸算法對(duì)二叉樹(shù)分別進(jìn)行先序、中序、后序遍歷。</p><p> ?、?以隊(duì)列為輔助結(jié)構(gòu)實(shí)現(xiàn)二叉樹(shù)的層次遍歷。</p><p> ?、?結(jié)合先序遍歷,以凹入表形式輸出二叉樹(shù)。</p><p>  //定義二叉樹(shù)結(jié)點(diǎn)結(jié)構(gòu)和操作

19、的頭文件btree1.h </p><p>  //定義二叉樹(shù)結(jié)點(diǎn)值的類(lèi)型為字符型</p><p>  typedef char ElemType; </p><p>  //定義二叉樹(shù)結(jié)點(diǎn)類(lèi)型</p><p>  struct BTreeNode {</p><p>  ElemType data;</p&

20、gt;<p>  BTreeNode* left;</p><p>  BTreeNode* right;</p><p><b>  }; </b></p><p>  //初始化二叉樹(shù),即把樹(shù)根指針置空</p><p>  void InitBTree(BTreeNode*& BT);<

21、/p><p>  //判斷二叉樹(shù)是否為空</p><p>  bool BTreeEmpty(BTreeNode* BT);</p><p>  1.1.1 二叉樹(shù)的遍歷</p><p>  二叉樹(shù)的遍歷即是如何按照某條路徑尋訪每一個(gè)結(jié)點(diǎn),使得每個(gè)結(jié)點(diǎn)均被訪問(wèn)一次,而且僅被訪問(wèn)一次。“訪問(wèn)”的含義很廣,可以是對(duì)結(jié)點(diǎn)做出各種處理,如輸出結(jié)點(diǎn)的信息

22、等。遍歷對(duì)線性結(jié)構(gòu)來(lái)說(shuō)是一個(gè)容易解決的問(wèn)題,而對(duì)于二叉樹(shù)則不然,由于二叉樹(shù)是一種非線性結(jié)構(gòu),每個(gè)結(jié)點(diǎn)都有可能有倆棵子樹(shù),因而需要尋找一種規(guī)律,以便使二叉樹(shù)上的結(jié)點(diǎn)都能夠排列在線性隊(duì)列上,從而便于遍歷。</p><p>  二叉樹(shù)室友三個(gè)基本單位組成的:根節(jié)點(diǎn) 左子樹(shù)和右子樹(shù)。因而遍歷著三個(gè)部分,便是遍歷了整個(gè)二叉樹(shù)。</p><p>  void TraverseBTree(BTreeNo

23、de* BT, int mark)</p><p><b>  {</b></p><p>  if(mark==1) { //先序遍歷</p><p>  if(BT!=NULL) {</p><p>  cout<<BT->data<<' ';</p>&

24、lt;p>  TraverseBTree(BT->left,mark);</p><p>  TraverseBTree(BT->right,mark);</p><p><b>  }</b></p><p><b>  }</b></p><p>  else if(mark=

25、=2) { //中序遍歷</p><p>  if(BT!=NULL) {</p><p>  TraverseBTree(BT->left,mark);</p><p>  cout<<BT->data<<' ';</p><p>  TraverseBTree(BT->right

26、,mark);</p><p><b>  }</b></p><p><b>  }</b></p><p>  else if(mark==3) { //后序遍歷</p><p>  if(BT!=NULL) {</p><p>  TraverseBTree(BT-&

27、gt;left,mark);</p><p>  TraverseBTree(BT->right,mark);</p><p>  cout<<BT->data<<' ';</p><p><b>  }</b></p><p><b>  }</b&g

28、t;</p><p>  else if(mark==4) //按層遍歷</p><p><b>  {</b></p><p>  const MaxLength=30;</p><p>  BTreeNode* Q[MaxLength];</p><p>  //定義存儲(chǔ)二叉樹(shù)結(jié)點(diǎn)指針的數(shù)組

29、空間作為隊(duì)列使用</p><p>  int front=0, rear=0;</p><p>  //定義隊(duì)首指針和隊(duì)尾指針,初始均置0表示空隊(duì)</p><p>  BTreeNode* p;</p><p><b> ?。?lt;/b></p><p>  求二叉樹(shù)的結(jié)點(diǎn)總數(shù) 葉子節(jié)點(diǎn)個(gè)數(shù)</

30、p><p><b>  及二叉樹(shù)的深度</b></p><p>  //用于求二叉樹(shù)深度的遞歸函數(shù)</p><p>  int Depth(BTreeNode* BT)</p><p><b>  {</b></p><p>  if(BT==NULL)</p>&

31、lt;p>  return 0; //對(duì)于空樹(shù),返回0并結(jié)束遞歸</p><p><b>  else</b></p><p><b>  {</b></p><p>  //計(jì)算左子樹(shù)的深度</p><p>  int dep1=Depth(BT->left);</p>

32、<p>  //計(jì)算右子樹(shù)的深度</p><p>  int dep2=Depth(BT->right);</p><p><b>  //返回樹(shù)的深度</b></p><p>  if(dep1>dep2) return dep1+1; </p><p>  else return dep2+1

33、;</p><p><b> ?。?lt;/b></p><p><b>  }</b></p><p>  //求二叉樹(shù)中所有結(jié)點(diǎn)數(shù)</p><p>  int BinaryTree::BTreeCount()</p><p><b>  { </b><

34、;/p><p>  return Count(root);</p><p><b>  }</b></p><p>  //用于求二叉樹(shù)中所有結(jié)點(diǎn)數(shù)的遞歸函數(shù)</p><p>  int Count(BTreeNode* BT)</p><p><b>  {</b></p

35、><p>  if(BT==NULL) return 0;</p><p><b>  else</b></p><p>  return Count(BT->left)+Count(BT->right)+1;</p><p><b>  }</b></p><p>

36、  //求二叉樹(shù)中所有葉子結(jié)點(diǎn)數(shù)</p><p>  int BinaryTree::BTreeLeafCount()</p><p><b>  {</b></p><p>  return LeafCount(root);</p><p><b>  }</b></p><p

37、>  //用于求二叉樹(shù)中所有葉子結(jié)點(diǎn)數(shù)的遞歸函數(shù)</p><p>  int LeafCount(BTreeNode* BT)</p><p><b>  {</b></p><p>  if(BT==NULL) return 0;</p><p>  else if(BT->left==NULL &

38、& BT->right==NULL) return 1;</p><p>  else return LeafCount(BT->left)+LeafCount(BT->right);</p><p><b> ?。?lt;/b></p><p><b>  調(diào)試結(jié)果</b></p>&l

39、t;p><b>  測(cè)試數(shù)據(jù)</b></p><p>  1.輸入:ABC+DE+G++F+++(其中+表示空格字符)</p><p><b>  則輸出結(jié)果為:</b></p><p>  先序:ABCDEGF</p><p>  中序:CBEGDFA</p><p>

40、;  后序:CGEFDBA</p><p>  2.輸入:AB+DG+++CE++F++</p><p>  先序:ABDGCEF</p><p>  中序:BGDAECF</p><p>  后序:GDBEFCA</p><p>  3.輸入:ABDF++++C+E+G++</p><p> 

41、 先序:ABDFCEG</p><p>  中序:FDBACEG</p><p>  后序:FDBGECA</p><p>  第五章 實(shí)習(xí)體會(huì)</p><p>  數(shù)據(jù)結(jié)構(gòu)的實(shí)習(xí)是培養(yǎng)學(xué)生綜合運(yùn)用所學(xué)知識(shí),發(fā)現(xiàn),提出,分析和解決實(shí)際問(wèn)題,鍛煉實(shí)踐能力的重要環(huán)節(jié),是對(duì)學(xué)生實(shí)際工作能力的具體訓(xùn)練和考察過(guò)程. 回顧起此數(shù)據(jù)結(jié)構(gòu)實(shí)習(xí),至今我仍

42、感慨頗多,的確,從選題到定稿,從理論到實(shí)踐,在整整兩星期的日子里,可以說(shuō)得是苦多于甜,但是可以學(xué)到很多很多的的東西,同時(shí)不僅可以鞏固了以前所學(xué)過(guò)的知識(shí),而且學(xué)到了很多在書(shū)本上所沒(méi)有學(xué)到過(guò)的知識(shí)。通過(guò)這次實(shí)習(xí)使我懂得了理論與實(shí)際相結(jié)合是很重要的,只有理論知識(shí)是遠(yuǎn)遠(yuǎn)不夠的,只有把所學(xué)的理論知識(shí)與實(shí)踐相結(jié)合起來(lái),從理論中得出結(jié)論,從而提高自己的實(shí)際動(dòng)手能力和獨(dú)立思考的能力。在設(shè)計(jì)的過(guò)程中遇到問(wèn)題,可以說(shuō)得是困難重重,這畢竟第一次做的,難免會(huì)遇

43、到過(guò)各種各樣的問(wèn)題,同時(shí)在設(shè)計(jì)的過(guò)程中發(fā)現(xiàn)了自己的不足之處,對(duì)以前所學(xué)過(guò)的知識(shí)理解得不夠深刻,掌握得不夠牢固。</p><p>  經(jīng)過(guò)兩個(gè)星期的上機(jī)實(shí)踐學(xué)習(xí),使我對(duì)數(shù)據(jù)機(jī)構(gòu)有了更進(jìn)一步的認(rèn)識(shí)和了解,要想學(xué)好它要重在實(shí)踐,要通過(guò)不斷的上機(jī)操作才能更好地學(xué)習(xí)它,通過(guò)實(shí)踐,我也發(fā)現(xiàn)我的好多不足之處,首先是自己對(duì)知識(shí)點(diǎn)的掌握不夠熟悉,通過(guò)學(xué)習(xí)也有所改進(jìn);再有對(duì)C語(yǔ)言的一些標(biāo)準(zhǔn)庫(kù)函數(shù)不太了解,還有對(duì)函數(shù)調(diào)用的正確使用不夠

44、熟悉,還有對(duì)C語(yǔ)言中經(jīng)常出現(xiàn)的錯(cuò)誤也不了解,通過(guò)實(shí)踐,使我在這幾個(gè)方面的認(rèn)識(shí)有所提高。通過(guò)實(shí)踐的學(xué)習(xí),我認(rèn)到學(xué)好計(jì)算機(jī)要重視實(shí)踐操作,不僅僅是學(xué)習(xí)C語(yǔ)言,還是其它的語(yǔ)言,以及其它的計(jì)算機(jī)方面的知識(shí)都要重在實(shí)踐,所以后在學(xué)習(xí)過(guò)程中,我會(huì)更加注視實(shí)踐操作,使自己便好地學(xué)好計(jì)算機(jī)。 </p><p>  在今后的日子里,認(rèn)真對(duì)待每意見(jiàn)事,爭(zhēng)取做到最好,努力將知識(shí)與實(shí)踐相結(jié)合,不斷鞏固,加深所學(xué)的知識(shí),做到學(xué)

45、以致用。</p><p><b>  參考文獻(xiàn):</b></p><p>  1.嚴(yán)蔚敏、吳偉民,《數(shù)據(jù)結(jié)構(gòu)》(C語(yǔ)言版),北京:清華大學(xué)出版社,2006.5</p><p>  2.寧正元、易金聰,《數(shù)據(jù)結(jié)構(gòu)習(xí)題解析與上機(jī)實(shí)驗(yàn)指導(dǎo)》,中國(guó)水利水電出版社、上海交通大學(xué)出版社、東南大學(xué)出版社,2002.6</p><p>

46、  3.劉懷亮,《數(shù)據(jù)結(jié)構(gòu)習(xí)題解析與實(shí)驗(yàn)指導(dǎo)》(C語(yǔ)言描述),冶金工業(yè)出版社,2005.2</p><p>  目 錄</p><p>  程序要求 —————————————— 1</p><p>  算法分析 —————————————— 1 </p><p>  二叉樹(shù)的基本操作和算法實(shí)現(xiàn)———————

47、 1 </p><p>  1.1 二叉樹(shù)的創(chuàng)建 ---------------------------------- 4</p><p>  1.1.1 二叉樹(shù)的遍歷 -------------------------------- 7 </p><p>  1.1.1.1 求二叉樹(shù)的結(jié)

溫馨提示

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