-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathConstructTreeFromPre_InOrder.java
More file actions
50 lines (45 loc) · 1.53 KB
/
ConstructTreeFromPre_InOrder.java
File metadata and controls
50 lines (45 loc) · 1.53 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
50
package BinaryTree;
import java.util.*;
public class ConstructTreeFromPre_InOrder {
static ArrayList<Integer> ans = new ArrayList<>();
public static void main(String[] args) {
int preorder[] = {10,20,40,50,30,60};
int inorder[] = {40,20,50,10,60,30};
TreeNode root = buildTree(preorder, inorder);
Display_levelOrder(root);
System.out.println(ans);
}
public static TreeNode buildTree(int[] pre , int[] in)
{
if(in.length != pre.length)return null;
Map<Integer,Integer> map = new HashMap<>();
for(int i = 0 ; i<in.length ; i++)
{
map.put(in[i],i);
}
return createTree(pre , map , 0 , in.length-1);
}
static int j = 0;
public static TreeNode createTree(int[] pre , Map<Integer,Integer> map , int start , int end)
{
if(start>end)return null;
TreeNode root = new TreeNode(pre[j]);
int pos = map.get(pre[j++]);
root.left = createTree(pre , map , start , pos - 1);
root.right = createTree(pre ,map ,pos+1 , end);
return root;
}
public static void Display_levelOrder(TreeNode root)
{
if(root == null)return;
Queue<TreeNode> q = new LinkedList<>();
q.add(root);
while (!q.isEmpty())
{
TreeNode node = q.poll();
ans.add(node.data);
if(node.left != null)q.add(node.left);
if(node.right != null)q.add(node.right);
}
}
}