劍指 Offer 36 二叉搜尋樹與雙向鍊錶

2021-10-20 14:54:08 字數 593 閱讀 9960

題目:把二叉搜尋樹轉化為元素有序的雙向迴圈鍊錶。(因為二叉樹有左右指標,雙遍鍊錶也有左右指標)

public node treetodoublylist(node root)

思路

二叉搜尋樹的中序遍歷為有序。所以用中序遍歷。

用pre指標儲存上一層遞迴中root的指向剛開始pre為null,可以確定head。然後pre比root慢一拍然後一直往後)。用pre和下一層遞迴的root進行連線。

最後pre停在鍊錶尾部,直接把pre當做尾,和head進行連線,然後返回。

public

class

binaryserachtreetodoublylinkedlist

public

void

inorder

(node root)

else

pre = cur;

inorder

(root.right);}

}

劍指Offer 36 二叉搜尋樹與雙向鍊錶

20.5.4 將 二叉搜尋樹 轉換成乙個 排序的迴圈雙向鍊錶 其中包含三個要素 排序鍊錶 節點應從小到大排序,因此應使用中序遍歷 從小到大 訪問樹的節點 雙向鍊錶 在構建相鄰節點 設前驅節點 pre 當前節點 cur 關係時,不僅應 pre.right cur,也應 cur.left pre 迴圈鍊...

《劍指offer》 36二叉搜尋樹與雙向鍊錶

輸入一棵二叉搜尋樹,將該二叉搜尋樹轉換成乙個排序的雙向鍊錶。要求不能建立任何新的結點,只能調整樹中結點指標的指向。思路 public class treenode public class solution 右子樹轉換後,返回頭結點,連線在根節點右側 treenode rightnode conve...

劍指offer 36 二叉搜尋樹與雙向鍊錶

輸入一棵二叉搜尋樹,將該二叉搜尋樹轉換成乙個排序的迴圈雙向鍊錶。要求不能建立任何新的節點,只能調整樹中節點指標的指向。為了讓您更好地理解問題,以下面的二叉搜尋樹為例 我們希望將這個二叉搜尋樹轉化為雙向迴圈鍊錶。鍊錶中的每個節點都有乙個前驅和後繼指標。對於雙向迴圈鍊錶,第乙個節點的前驅是最後乙個節點,...