18 重建二叉樹

2021-10-05 08:00:43 字數 764 閱讀 5350

輸入一棵二叉樹前序遍歷和中序遍歷的結果,請重建該二叉樹。

注意:

樣例

給定:

前序遍歷是:[3, 9, 20, 15, 7]

中序遍歷是:[9, 3, 15, 20, 7]

返回:[3, 9, 20, null, null, 15, 7, null, null, null, null]

返回的二叉樹如下所示:

3/ \

9 20

/ \

15 7

/**

* definition for a binary tree node.

* struct treenode

* };

*/class solution

/* * 遞迴) o(n)o(n)

遞迴建立整棵二叉樹:先遞迴建立左右子樹,然後建立根節點,並讓指標指向兩棵子樹。

具體步驟如下:

1: 先利用前序遍歷找根節點:前序遍歷的第乙個數,就是根節點的值;

2: 在中序遍歷中找到根節點的位置 kk,則 kk 左邊是左子樹的中序遍歷,右邊是右子樹的中序遍歷;

3: 假設左子樹的中序遍歷的長度是 ll,則在前序遍歷中,根節點後面的 ll 個數,是左子樹的前序遍歷,剩下的數是右子樹的前序遍歷;

4: 有了左右子樹的前序遍歷和中序遍歷,我們可以先遞迴建立出左右子樹,然後再建立根節點;

* */

};

二叉樹24 重建二叉樹

題目 輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列和中序遍歷序列,則重建二叉樹並返回。思路 已知一棵樹的先序遍歷的結果陣列和中序遍歷的結果,要求據此重建一棵二叉樹,即重建所有結點並設定結點之間的指標關係,最後返回...

二叉樹 2255 重建二叉樹

總時間限制 1000ms 記憶體限制 65536kb 描述給定一棵二叉樹的前序遍歷和中序遍歷的結果,求其後序遍歷。輸入輸入可能有多組,以eof結束。每組輸入包含兩個字串,分別為樹的前序遍歷和中序遍歷。每個字串中只包含大寫字母且互不重複。輸出對於每組輸入,用一行來輸出它後序遍歷結果。樣例輸入 dbac...

3 9 重建二叉樹

題目 給定一顆樹的先序遍歷結果和中序遍歷的結果,重建這顆樹。例如 前序 ab d c e f 中序 d bae c f a是根節點。思路 根據前序,可以很快找出根節點a,然後根據中序,可以找出根節點a的左右子樹,然後遞迴求a的左子樹前序b d跟中序d b,a的右子樹前序c e f跟中序e c f即可...