-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathQuestion236.java
More file actions
92 lines (79 loc) · 2.44 KB
/
Copy pathQuestion236.java
File metadata and controls
92 lines (79 loc) · 2.44 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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
import java.util.*;
public class Question236
{
public static void getPath(TreeNode root, TreeNode node, List<TreeNode> result,boolean[] flag)
{
result.add(root);
if(root.val == node.val)
{
flag[0] = true;
return;
}
else
{
//Move left
if(root.left!=null && flag[0] == false)
{
getPath(root.left,node,result,flag);
if(flag[0] == false)
result.remove(result.size()-1);
}
//Move right
if(root.right!=null && flag[0] == false)
{
getPath(root.right,node,result,flag);
if(flag[0] == false)
result.remove(result.size()-1);
}
}
}
public static TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q)
{
List<TreeNode> result1 = new ArrayList<>();
List<TreeNode> result2 = new ArrayList<>();
boolean[] flag = new boolean[1];
flag[0] = false;
getPath(root,p,result1,flag);
flag[0] = false;
getPath(root,q,result2,flag);
System.out.println(result1);
System.out.println(result2);
TreeNode tn = null;
if(result1.size()<result2.size())
{
for(TreeNode t:result1)
{
if(result2.contains(t))
tn = t;
}
}
else
{
for(TreeNode t:result2)
{
if(result1.contains(t))
tn = t;
}
}
return tn;
}
public static void main(String[] args)
{
TreeNode root = new TreeNode(10,null,null);
TreeNode l1 = new TreeNode(7,null,null);
TreeNode r1 = new TreeNode(12,null,null);
TreeNode ll2 = new TreeNode(-3,null,null);
TreeNode rr2 = new TreeNode(20,null,null);
TreeNode last = new TreeNode(33,null,null);
TreeNode lastnew = new TreeNode(123,null,null);
root.left = l1;
root.right = r1;
l1.left = ll2;
r1.right = rr2;
rr2.right = last;
ll2.right = lastnew;
Trees.display(root);
TreeNode result = lowestCommonAncestor(root,rr2,lastnew);
System.out.println("LCA : "+result.val);
}
}