- 1、本文档共122页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
树状结构
第7 章
第7 章
樹狀結構
樹狀結構
本章學習目標 .
理解樹、二元樹、林的定義。
理解如何動態建立二元樹
理解二元樹的走訪演算法。
理解引線二元樹與相關演算法。
理解累堆、二元搜尋樹與相關演算法。
樹狀結構 7-2
7.1 樹狀結構簡介
樹(Tree )是一種非線性的資料結構,在日常生活中,我們常常可以看到樹狀結
構的應用,例如男性族譜關係是一種樹狀結構(如圖7-1 )。
圖7- 1 家族表呈現樹狀結構
樹狀結構 7-3
7.1.1 樹的定義
以圖示來看,可以很容易看出一個結構是否為樹狀結構,但這並不夠嚴謹。
樹其實是(有向)圖的一種特例(下一章介紹),但在此我們先不管圖的部分,
而是將『樹』採用遞迴方式定義如下:
7- 1
【定義 】樹的定義
樹是由一個以上的節點所構成的有限集合,它必須滿足下列兩個條
件:
(1) 具有唯一的特殊節點,稱為樹根或根節點(root )。
(2) n T , T , T , ..., T (n0)
剩下的節點分為 個互斥集合 1 2 3 n ,每一個集合
Ti 也都是一棵獨立的樹,並稱為樹根的子樹(subtree )。
採用遞迴定義,使得樹狀結構的定義得以簡潔。
以圖7-1 為例,『諸葛珪』是根節點,並有三棵子樹,其三棵子樹的樹根分別
為『諸葛瑾』、『諸葛亮』、『諸葛均』。
請特別注意定義的第(2)點,子樹T , T , ..., T 必須是互斥且獨立集合,也就是這些
1 2 n
子樹不可以連接在一起。
樹狀結構 7-4
此外,在遞迴定義中,我們可以發現,除了根節點之外,樹的任何一個節點必定
為某一個子樹的根節點。
以『諸葛懷』節點為例,它是『諸葛懷』子樹的根節點,且『諸葛懷』並未
擁有子樹,而這仍符合定義的第(2)項規定,只是此時n 恰為0。
7.1.2 樹狀結構的專有名詞
在了解樹的定義之後,我們還必須介紹樹的相關專有名詞,我們透過圖7-2 為例,
說明其他必須了解的專有名詞(習慣上,我們會將樹根畫在最上面)。
樹狀結構 7-5
圖7-2 樹的專有名詞
1. node branch
節點( ):代表某項資料及其指向其它資料項的分支( ),
directed edge
這個分支是個有方向性的邊( )(邊的定義詳見下一章),
7-2 A 3
如圖 的根節點的資料項目為 ,分支有 個。
2. parent node children node X
文档评论(0)