Skip to content

Commit 3f19147

Browse files
committed
Added Find Nearest Right Node in Binary Tree.java
1 parent 8760dcc commit 3f19147

File tree

1 file changed

+47
-0
lines changed

1 file changed

+47
-0
lines changed
Lines changed: 47 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,47 @@
1+
/**
2+
* Definition for a binary tree node.
3+
* public class TreeNode {
4+
* int val;
5+
* TreeNode left;
6+
* TreeNode right;
7+
* TreeNode() {}
8+
* TreeNode(int val) { this.val = val; }
9+
* TreeNode(int val, TreeNode left, TreeNode right) {
10+
* this.val = val;
11+
* this.left = left;
12+
* this.right = right;
13+
* }
14+
* }
15+
*/
16+
class Solution {
17+
public TreeNode findNeartestRightNode(TreeNode root, TreeNode u) {
18+
if (root == null) {
19+
return null;
20+
}
21+
Queue<TreeNode> queue = new LinkedList<>();
22+
queue.add(root);
23+
boolean found = false;
24+
while (!queue.isEmpty()) {
25+
int size = queue.size();
26+
while (size-- > 0) {
27+
TreeNode removed = queue.remove();
28+
if (found) {
29+
return removed;
30+
}
31+
if (removed == u) {
32+
found = true;
33+
}
34+
if (removed.left != null) {
35+
queue.add(removed.left);
36+
}
37+
if (removed.right != null) {
38+
queue.add(removed.right);
39+
}
40+
}
41+
if (found) {
42+
break;
43+
}
44+
}
45+
return null;
46+
}
47+
}

0 commit comments

Comments
 (0)