leetcode原題: 劍指 offer 36
輸入一棵二叉搜尋樹,將該二叉搜尋樹轉換成乙個排序的迴圈雙向鍊錶。要求不能建立任何新的節點,只能調整樹中節點指標的指向。
我們希望將這個二叉搜尋樹轉化為雙向迴圈鍊錶。鍊錶中的每個節點都有乙個前驅和後繼指標。對於雙向迴圈鍊錶,第乙個節點的前驅是最後乙個節點,最後乙個節點的後繼是第乙個節點。
下圖展示了上面的二叉搜尋樹轉化成的鍊錶。「head」 表示指向鍊錶中有最小元素的節點。
特別地,我們希望可以就地完成轉換操作。當轉化完成以後,樹中節點的左指標需要指向前驅,樹中節點的右指標需要指向後繼。還需要返回鍊錶中的第乙個節點的指標。
不能建立新節點來實現, 就不能像複雜鍊錶複製一樣,建立新節點來去構造完全新的鍊錶. 思路是 二叉搜尋樹, 它的中序遍歷是 遞增的, 那麼就能夠在中序遍歷時做鍊錶連線的事情, 這時候只需要考慮怎樣得到當前節點的 pre 乙個節點就能夠解決了!
/**
* // definition for a node.
* function node(val,left,right) ;
*//** * @param root
* @return
*/vartreetodoublylist
=function
(root)
};
面試題:
乙個 tcp 連線可以發多少個 http 請求?
二叉搜尋樹轉化為雙向鍊錶
首先需要明白二叉搜尋樹也是一種排序的資料結構,它的中序遍歷就是乙個不遞減的順序排列 所以如果要轉換成乙個排序好的雙向鍊錶,那麼僅需要改變原來指向左子節點和右子節點的指標,讓他們分別指向前節點和後節點即可,如圖所示 調整指標 原先指向左子節點的指標調整為鍊錶中指向前乙個節點的指標 原先指向右子節點的指...
二叉搜尋樹轉化為雙向鍊錶
整個過程可以看做是三部分的鍊錶化,左子樹 根節點和右子樹。遞迴地對這三部分進行鍊錶化,在鍊錶化中處理好左子樹最右節點與根節點的鏈結關係 根節點與右子樹的關係,那麼整個過程就能夠完成。treenode convert treenode root void convertnode treenode no...
將二叉搜尋樹轉化為雙向鍊錶
輸入一棵二叉搜尋樹,將該二叉搜尋樹轉換成乙個排序的雙向鍊錶。要求不能建立任何新的結點,只能調整樹中結點指標的指向。建立的雙向鍊錶的順序就是二叉搜尋樹的中序遍歷結果。這裡有遞迴和非遞迴解法。一般的非遞迴解法需要開闢額外的空間,本次借助morris演算法,給出一種不需要額外空間開銷的非遞迴解法。首先是遞...