106. 从中序与后序遍历序列构造二叉树.svg

    1. /**
    2. * Definition for a binary tree node.
    3. * public class TreeNode {
    4. * int val;
    5. * TreeNode left;
    6. * TreeNode right;
    7. * TreeNode(int x) { val = x; }
    8. * }
    9. */
    10. class Solution {
    11. public TreeNode buildTree(int[] inorder, int[] postorder) {
    12. int postlength = postorder.length;
    13. int inlength = inorder.length;
    14. Map<Integer, Integer> map = new HashMap();
    15. for (int i = 0; i < inlength; i++) {
    16. map.put(inorder[i], i);
    17. }
    18. return buildTree(postorder, 0, postlength - 1, map, 0, inlength - 1);
    19. }
    20. public TreeNode buildTree(int[] postorder, int postLeft, int postRight, Map<Integer, Integer> inorder, int inLeft, int inRight) {
    21. if (postLeft > postRight || inLeft > inRight) {
    22. return null;
    23. }
    24. int val = postorder[postRight];
    25. int pIndex = inorder.get(val);
    26. TreeNode root = new TreeNode(val);
    27. root.left = buildTree(postorder, postLeft, postRight - pIndex + inLeft - 1, inorder, inLeft, pIndex - 1);
    28. root.right = buildTree(postorder, postRight - pIndex + inLeft, postRight - 1, inorder, pIndex + 1, inRight);
    29. return root;
    30. }
    31. }