劍指offer面試題8 二叉樹的下乙個節點

2021-10-02 23:16:37 字數 619 閱讀 3190

/*

樹中的節點除了有左右指標還有乙個指向父節點的指標

a/ \

b c

/ \ / \

d e f g

/ \

h i

它的中序遍歷是

*//*

1.如果乙個節點有右子樹,那麼它的下乙個節點就是它的右子樹中最左子節點,例如b的下乙個是h

2.如果乙個節點沒有右子樹,如果這個節點是它父節點的左節點,那麼它的下乙個節點就是它的父節點

3.如果乙個節點既沒有右子樹,這個節點還是它父節點的右子節點,那麼我們可以沿著父節點的指標一直向上遍歷,直到找到乙個是它父節點的左子節點的節點,那麼這個節點的父節點就是我們要找的下乙個節點

*/binarytreenode *

getnext

(binarytreenode *pnode)

else

if(pnode-

>parent !=

nullptr

) pnext=pparent;

}return pnext;

}

《劍指Offer》面試題 平衡二叉樹

題目 輸入乙個二叉樹的根節點,判斷該樹是不是平衡二叉樹。如果某二叉樹中任意節點的左右子樹的深度相差不超過1,那麼它就是一棵平衡二叉樹。思路 用後序遍歷實現 先遍歷節點的左右子樹,左右子樹都平衡才來判斷該節點是否平衡,如果左右子樹中有不平衡的,則直接返回false,避免了從上往下逐個節點地計算深度帶來...

劍指Offer 面試題 樹和二叉樹

題目描述 輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列和中序遍歷序列,則重建二叉樹並返回。基礎知識 在二叉樹的前序遍歷序列中,第乙個數字總是樹的根節點的值。在中序遍歷序列中,根節點的值在序列的中間,左子樹的節點的...

《劍指Offer》面試題 二叉樹的深度

題目描述 輸入一棵二叉樹,求該樹的深度。從根結點到葉結點依次經過的結點 含根 葉結點 形成樹的一條路徑,最長路徑的長度為樹的深度。思路 此題的遞迴思想比較簡單,直接用遞迴將根節點的深度轉換為求左右子孩子的深度的較大值 1,根節點的深度等於max 左孩子的深度,右孩子的深度 輸入 第一行輸入有n,n表...