輸入一棵二叉樹前序遍歷和中序遍歷的結果,請重建該二叉樹。
注意:
樣例
給定:
前序遍歷是:[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即可...