Untitled Diagram.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[] preorder, int[] inorder) {
    12. int prelength = preorder.length;
    13. int inlength = inorder.length;
    14. Map<Integer, Integer> inorderMap = new HashMap();
    15. for (int i = 0; i < inlength; i++) {
    16. inorderMap.put(inorder[i], i);
    17. }
    18. return buildTree(preorder, 0, prelength - 1, inorderMap, 0, inlength - 1);
    19. }
    20. public TreeNode buildTree(int[] preorder, int preLeft, int preRight, Map<Integer, Integer> inorderMap, int inLeft, int inRight) {
    21. if (preLeft > preRight) {
    22. return null;
    23. }
    24. int val = preorder[preLeft];
    25. TreeNode root = new TreeNode(val);
    26. int pIndex = inorderMap.get(val);
    27. root.left = buildTree(preorder, preLeft + 1, preLeft + pIndex - inLeft, inorderMap, inLeft, pIndex - 1);
    28. root.right = buildTree(preorder, preLeft + pIndex - inLeft + 1, preRight, inorderMap, pIndex + 1, inRight);
    29. return root;
    30. }
    31. }