https://leetcode.com/problems/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
代码:
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */ class Solution { public: TreeNode* buildTree(vector<int>& inorder, vector<int>& postorder) { return helper(inorder, 0, inorder.size() - 1, postorder, 0, postorder.size() - 1); } TreeNode* helper(vector<int> &inorder, int ileft, int iright, vector<int> &postorder, int pleft, int pright) { if(ileft > iright || pleft > pright) return NULL; int i = 0; for(i = ileft; i < inorder.size(); ++ i) if(inorder[i] == postorder[pright]) break; TreeNode *cur = new TreeNode(postorder[pright]); cur -> left = helper(inorder, ileft, i - 1, postorder, pleft, pleft + i - ileft -1); cur -> right = helper(inorder, i + 1, iright, postorder, pleft + i - ileft, pright - 1); return cur; } };
终于搞完了期末大作业剩下的就只有考试了 可爱 Be 主又每天在线10h + 激情刷题了 工作日倒数第二天 要迎接元旦假期了呢