From 7e76006b8f7a4cdc94dff0ce1fec818c3b4a89cf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=94=90=E6=A0=91=E6=A3=AE?= Date: Fri, 26 Apr 2019 23:29:57 +0800 Subject: [PATCH] Create 106. Construct Binary Tree from Inorder and Postorder Traversal.md --- ...ee from Inorder and Postorder Traversal.md | 35 +++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 solutions/106. Construct Binary Tree from Inorder and Postorder Traversal.md diff --git a/solutions/106. Construct Binary Tree from Inorder and Postorder Traversal.md b/solutions/106. Construct Binary Tree from Inorder and Postorder Traversal.md new file mode 100644 index 0000000..305d201 --- /dev/null +++ b/solutions/106. Construct Binary Tree from Inorder and Postorder Traversal.md @@ -0,0 +1,35 @@ +# [106. Construct Binary Tree from Inorder and Postorder Traversal](https://leetcode.com/problems/construct-binary-tree-from-inorder-and-postorder-traversal/) +# 思路 +根据中序遍历和后序遍历构建二叉树。 +其实和105题(根据中序遍历和前序遍历构建二叉树)是类似的,由于后序遍历的最后一个肯定是根,所以原二叉树的根节点可以知道,然后由于树中没有相同元素, +所以我们可以在中序遍历中也定位出根节点的位置,并以根节点的位置将中序遍历拆分为左右两个部分,分别对其递归调用原函数。 +其中在中序遍历中定位根节点可以通过hash(即unordered_map)实现。 + +# C++ +``` C++ +class Solution { +private: + TreeNode* helper(int num, vector& postorder, int post_last, + vector& inorder, int in_start, + unordered_map& mp){ + if(num == 0) return NULL; + int val = postorder[post_last]; + TreeNode *node = new TreeNode(val); + int i = mp[val] - in_start; // i代表左子树有多少个节点 + node -> left = helper(i, postorder, post_last - num + i, inorder, in_start, mp); + node -> right = helper(num-i-1, postorder, post_last-1, inorder, + in_start+i+1, mp); + return node; + } +public: + TreeNode* buildTree(vector& inorder, vector& postorder) { + unordered_mapmp; + // 用mp记录某个节点在中序遍历数组中的索引 + for(int i = 0; i < inorder.size(); i++) mp[inorder[i]] = i; + int num = postorder.size(); + return helper(num, postorder, num - 1, inorder, 0, mp); + + } +}; +``` +