1、樹轉換為二叉樹
---- 將樹轉換為二叉樹的步驟如下:
--1)加線。在所有兄弟結點之間加一條連線。
--2)去線。對樹中每個結點,只保留它與第乙個孩子結點的連線,刪除它與其他孩子結點之間的連線。
--3)層次調整。以樹的根結點為軸心,將整棵樹順時針旋轉一定的角度,使之結構層次分明。
注意第乙個孩子是二叉樹結點的左孩子,兄弟轉換過來的孩子是結點的右孩子。
例如下圖,一棵樹經過三個步驟轉換為一棵二叉樹。
2、森林轉換為二叉樹
---- 森林是由若干棵樹組成的,所以完全可以理解為:森林中的每一棵樹都是兄弟,可以按照兄弟的處理辦法來操作。
步驟如下:
--1)把每個樹轉換為二叉樹。
--2)第一棵二叉樹不動,從第二棵二叉樹開始,依次把後一棵二叉樹的根結點作為前一棵二叉樹的根結點的右孩子,用線連線起來。
當所有的二叉樹連線起來後就得到了由森林轉換來的二叉樹。
如下圖所示,將森林的三棵樹轉化為一棵二叉樹:
3、二叉樹轉換為樹
---- 二叉樹轉換為樹是樹轉換為二叉樹的逆過程,反過來做。步驟如下:
--1)加線。若某結點的左孩子結點存在,則將這個左孩子的右孩子結點、右孩子的右孩子結點.....右孩子的右孩子的右孩子的結點。。
左孩子的n個右孩子結點都作為此結點的孩子。將該結點與這些右孩子結點用線連線起來。
--2)去線。刪除原二叉樹中所有結點與其右孩子結點的連線。
--3)層次調整。使之結構層次分明。
---- 轉換過程如下圖所示:
4、二叉樹轉換為森林
---- 判斷一棵二叉樹能夠轉換為一棵樹還是森林,只要看這棵二叉樹的根結點有沒有右孩子,有就是森林,沒有就是一棵樹。
如果是轉換成森林,步驟如下:
--1)從根結點開始,若右孩子存在,則把與右孩子結點的連線刪除,再檢視分離後的二叉樹,若右孩子存在,則連線刪除......,
直到所有右孩子連線都刪除為止,得到分離的二叉樹。
--2)再將每棵分離後的二叉樹轉換為樹即可。
5、樹與森林的遍歷
---- 樹的遍歷分為兩種方式:
--1)一種是先根遍歷樹,即先訪問樹的根結點,然後依次先根遍歷根的每棵子樹。
--2)另一種是後根遍歷,即先依次後根遍歷每棵子樹,然後再訪問根結點。
如上圖的樹,先根遍歷序列為abefcdg,後根遍歷序列為efbcgda。
---- 森林的遍歷也分為兩種方式:
--1)前序遍歷:先訪問森林中第一棵樹的根結點,然後再依次先根遍歷根的每棵子樹,再依次用同樣方式遍歷除去第一棵樹的剩餘樹
構成的森林。
--2)後序遍歷:先訪問森林中第一棵樹,後根遍歷的方式遍歷每棵子樹,然後再訪問根結點,再依次同樣方式遍歷除去第一棵樹的剩餘
樹構成的森林。
如上圖有三棵樹的森林,前序遍歷序列的結果是:abcdefghji。後續遍歷的結果是:bcdafejhig。
通過對森林轉化為的二叉樹進行分析發現:
森林的前序遍歷和二叉樹的前序遍歷結果相同,森林的後序遍歷和二叉樹的中序遍歷結果相同。
---- 當以二叉鍊錶做樹的儲存結構時,樹的先根遍歷和後根遍歷完全可以借用二叉樹的前序遍歷和中序遍歷的演算法來實現。
找到了對樹和森林這種複雜問題的簡單解決辦法。
樹 森林與二叉樹的轉換
1 加線。在所有兄弟節點之間加一條線。2 去線。對樹中每個節點,只保留它與第乙個孩子節點的連線,刪除它與其他孩子節點之間的連線。3 層次調整。以樹的根節點為軸心,將整顆樹順時針旋轉一定的角度,使之結構層次分明。注意第乙個孩子是二叉樹節點的左孩子,兄弟轉換過來的孩子是節點的右孩子。1 把每個樹轉換為二...
樹 森林與二叉樹的轉換
樹或森林與二叉樹之間有乙個自然的一一對應關係。任何乙個森林或一棵樹可惟一地對應到一棵二叉樹 反之,任何一棵二叉樹也能惟一地對應到乙個森林或一棵樹。1 樹 森林到二叉樹的轉換 1 將樹轉換為二叉樹 樹中每個結點最多只有乙個最左邊的孩子 長子 和乙個右鄰的兄弟。按照這種關係很自然地就能將樹轉換成相應的二...
樹 森林與二叉樹的轉換
樹 森林與二叉樹的轉換 1 樹轉換為二叉樹 由於二叉樹是有序的,為了避免混淆,對於無序樹,我們約定樹中的每個結點的孩子結點按從左到右的順序進行編號。將樹轉換成二叉樹的步驟是 1 加線。就是在所有兄弟結點之間加一條連線 2 抹線。就是對樹中的每個結點,只保留他與第乙個孩子結點之間的連線,刪除它與其它孩...