-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathLeetCode0105.java
More file actions
49 lines (41 loc) · 1.77 KB
/
Copy pathLeetCode0105.java
File metadata and controls
49 lines (41 loc) · 1.77 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
/* Construct Binary Tree from Preorder and Inorder Traversal
* Input: preorder = [3,9,20,15,7]
inorder = [9,3,15,20,7]
* Output: 3
/ \
9 20
/ \
15 7
* */
import java.util.HashMap;
public class LeetCode0105 {
public static void main(String args[]) {
int[] preorder = {3, 9, 20, 15, 7};
int[] inorder = {9, 3, 15, 20, 7};
TreeNode t = buildTree(preorder, inorder);
TreeNode.output(t);
}
public static HashMap<Integer, Integer> map = new HashMap<>();
public static TreeNode buildTree(int[] preorder, int[] inorder) {
int length = preorder.length;
for (int i = 0; i < length; i++)
map.put(inorder[i], i);
return myBUildTree(preorder, inorder, 0, length - 1, 0, length - 1);
}
public static TreeNode myBUildTree(int[] preorder, int[] inorder, int preorder_left,
int preorder_right, int inorder_left, int inorder_right) {
if (preorder_left > preorder_right)
return null;
int preorder_root = preorder_left;
int inorder_root = map.get(preorder[preorder_root]);
TreeNode root = new TreeNode(preorder[preorder_root]); //根节点为前序遍历的第一个节点
int sizeOfLeft = inorder_root - inorder_left; //左子树节点数
//左子树
root.left = myBUildTree(preorder, inorder, preorder_left + 1,
preorder_left + sizeOfLeft, inorder_left, inorder_root - 1);
//右子树
root.right = myBUildTree(preorder, inorder, preorder_left + sizeOfLeft+1,
preorder_right, inorder_root+1, inorder_right);
return root;
}
}