Return any binary tree that matches the given preorder and postorder traversals.
Values in the traversals pre and post are distinct positive integers.
Example 1:
Input: pre = [1,2,4,5,3,6,7], post = [4,5,2,6,7,3,1]
Output: [1,2,3,4,5,6,7]
Note:
1 <= pre.length == post.length <= 30
pre[] and post[] are both permutations of 1, 2, ..., pre.length.
It is guaranteed an answer exists. If there exists multiple answers, you can return any of them.
ไปฃ็
Approach #1 Recursion
Time: O(N^2) && Space: O(N^2)
/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */classSolution {publicTreeNodeconstructFromPrePost(int[] pre,int[] post) {int N =pre.length;if (N ==0) returnnull;TreeNode root =newTreeNode(pre[0]);if (N ==1) return root;int L =0;for (int i =0; i < N; i++) {if (post[i] == pre[1]) L = i +1; }root.left=constructFromPrePost(Arrays.copyOfRange(pre,1, L+1),Arrays.copyOfRange(post,0, L));root.right=constructFromPrePost(Arrays.copyOfRange(pre, L+1, N),Arrays.copyOfRange(post, L, N-1));return root; }}
Approach #2
Create a node TreeNode(pre[preIndex]) as the root.
Becasue root node will be lastly iterated in post order, if root.val == post[posIndex], it means we have constructed the whole tree,
If we haven't completed constructed the whole tree, So we recursively constructFromPrePost for left sub tree and right sub tree.
And finally, we'll reach the posIndex that root.val == post[posIndex]. We increment posIndex and return our root node.