劍指offer 二叉樹的下乙個結點

2021-08-22 15:00:13 字數 516 閱讀 3081

**

給定乙個二叉樹和其中的乙個結點,請找出中序遍歷順序的下乙個結點並且返回。注意,樹中的結點不僅包含左右子結點,同時包含指向父結點的指標。

結合圖,我們可發現分成兩大類:1、有右子樹的,那麼下個結點就是右子樹最左邊的點;(eg:d,b,e,a,c,g) 2、沒有右子樹的,也可以分成兩類,a)是父節點左孩子(eg:n,i,l) ,那麼父節點就是下乙個節點 ; b)是父節點的右孩子(eg:h,j,k,m)找他的父節點的父節點的父節點...直到當前結點是其父節點的左孩子位置。如果沒有eg:m,那麼他就是尾節點。 

而第二種情況編寫**時又可以合在一起。

class solution 

else

return null;}}

};

自己捉摸了半天還是一團漿糊,分類的標準不正確(根本在於對中序遍歷二叉樹——左根右 理解不夠深刻)

劍指offer 二叉樹的下乙個結點

題目描述 給定乙個二叉樹和其中的乙個結點,請找出中序遍歷順序的下乙個結點並且返回。注意,樹中的結點不僅包含左右子結點,同時包含指向父結點的指標。using namespace std struct treelinknode class solution treelinknode nextnode n...

劍指offer 二叉樹的下乙個節點

給定乙個二叉樹和其中的乙個結點,請找出中序遍歷順序的下乙個結點並且返回。注意,樹中的結點不僅包含左右子結點,同時包含指向父結點的指標。在編寫程式之前,先縷清思路。在該題總,應該分不同情況對其進行討論。情況一 魯棒性 目標節點為空節點時返回ptr 情況二 目標節點沒有父節點且沒有右子樹時,即該節點就是...

劍指offer 二叉樹的下乙個節點

struct treelinknode class solution return currnode case two the node does not has right son,it is the left son of its father if pnode next null return...