C++實現(xiàn)LeetCode(106.由中序和后序遍歷建立二叉樹)
[LeetCode] 106. Construct Binary Tree from Inorder and Postorder Traversal 由中序和后序遍歷建立二叉樹
Given inorder and postorder traversal of a tree, construct the binary tree.
Note:
You may assume that duplicates do not exist in the tree.
For example, given
inorder = [9,3,15,20,7]
postorder = [9,15,7,20,3]
Return the following binary tree:
3
/ \
9 20
/ \
15 7
這道題要求從中序和后序遍歷的結(jié)果來重建原二叉樹,我們知道中序的遍歷順序是左-根-右,后序的順序是左-右-根,對于這種樹的重建一般都是采用遞歸來做,可參見博主之前的一篇博客 Convert Sorted Array to Binary Search Tree。針對這道題,由于后序的順序的最后一個肯定是根,所以原二叉樹的根結(jié)點可以知道,題目中給了一個很關(guān)鍵的條件就是樹中沒有相同元素,有了這個條件就可以在中序遍歷中也定位出根節(jié)點的位置,并以根節(jié)點的位置將中序遍歷拆分為左右兩個部分,分別對其遞歸調(diào)用原函數(shù)。代碼如下:
class Solution {
public:
TreeNode *buildTree(vector<int> &inorder, vector<int> &postorder) {
return buildTree(inorder, 0, inorder.size() - 1, postorder, 0, postorder.size() - 1);
}
TreeNode *buildTree(vector<int> &inorder, int iLeft, int iRight, vector<int> &postorder, int pLeft, int pRight) {
if (iLeft > iRight || pLeft > pRight) return NULL;
TreeNode *cur = new TreeNode(postorder[pRight]);
int i = 0;
for (i = iLeft; i < inorder.size(); ++i) {
if (inorder[i] == cur->val) break;
}
cur->left = buildTree(inorder, iLeft, i - 1, postorder, pLeft, pLeft + i - iLeft - 1);
cur->right = buildTree(inorder, i + 1, iRight, postorder, pLeft + i - iLeft, pRight - 1);
return cur;
}
};
上述代碼中需要小心的地方就是遞歸是 postorder 的左右 index 很容易寫錯,比如 pLeft + i - iLeft - 1, 這個又長又不好記,首先我們要記住 i - iLeft 是計算 inorder 中根節(jié)點位置和左邊起始點的距離,然后再加上 postorder 左邊起始點然后再減1。我們可以這樣分析,如果根結(jié)點就是左邊起始點的話,那么拆分的話左邊序列應(yīng)該為空集,此時 i - iLeft 為0, pLeft + 0 - 1 < pLeft, 那么再遞歸調(diào)用時就會返回 NULL, 成立。如果根節(jié)點是左邊起始點緊跟的一個,那么 i - iLeft 為1, pLeft + 1 - 1 = pLeft,再遞歸調(diào)用時還會生成一個節(jié)點,就是 pLeft 位置上的節(jié)點,為原二叉樹的一個葉節(jié)點。
下面來看一個例子, 某一二叉樹的中序和后序遍歷分別為:
Inorder: 11 4 5 13 8 9
Postorder: 11 4 13 9 8 5
11 4 5 13 8 9 => 5
11 4 13 9 8 5 / \
11 4 13 8 9 => 5
11 4 13 9 8 / \
4 8
11 13 9 => 5
11 13 9 / \
4 8
/ / \
11 13 9
Github 同步地址:
https://github.com/grandyang/leetcode/issues/106
類似題目:
Construct Binary Tree from Preorder and Postorder Traversal
Construct Binary Tree from Preorder and Inorder Traversal
參考資料:
https://leetcode.com/problems/construct-binary-tree-from-inorder-and-postorder-traversal/
到此這篇關(guān)于C++實現(xiàn)LeetCode(106.由中序和后序遍歷建立二叉樹)的文章就介紹到這了,更多相關(guān)C++實現(xiàn)由中序和后序遍歷建立二叉樹內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
深入學(xué)習(xí)C++智能指針之shared_ptr與右值引用的方法
智能指針的核心實現(xiàn)技術(shù)是引用計數(shù),每使用它一次,內(nèi)部引用計數(shù)加1,每析構(gòu)一次內(nèi)部的引用計數(shù)減1,減為0時,刪除所指向的堆內(nèi)存,今天通過本文給大家分享C++智能指針之shared_ptr與右值引用的方法,需要的朋友跟隨小編一起看看吧2021-07-07
C++ 中使用lambda代替 unique_ptr 的Deleter的方法
這篇文章主要介紹了C++ 中使用lambda代替 unique_ptr 的Deleter的方法,需要的朋友可以參考下2017-04-04
學(xué)習(xí)二維動態(tài)數(shù)組指針做矩陣運算的方法
這片文章介紹了如何利用二維動態(tài)數(shù)組指針做矩陣運算,需要的朋友可以參考下2015-07-07

