-
Notifications
You must be signed in to change notification settings - Fork 1k
/
Copy pathRightViewBT.java
126 lines (98 loc) · 2.71 KB
/
RightViewBT.java
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/*
Description:
Implementation of Right side view of Binary Tree
The Right view contains all nodes that are last nodes in their levels. A simple solution
is to do level order traversal and print the last node in every level.
*/
// Java Code -->
import java.util.*;
class Node
{
int key;
Node left = null, right = null;
Node(int key) {
this.key = key;
}
}
public class Right_Side_View_Of_BinaryTree{
public static Scanner sc=new Scanner(System.in);
public static Node BuildTree(){
//user inputs the values in preorder and enters -1 to denote a null node
int d=sc.nextInt();
if(d == -1)
return null;
//A new node created with value d
Node root = new Node(d);
//Recursive call to the left and right child of the root
root.left = BuildTree();
root.right = BuildTree();
return root;
}
public static void printRightView(Node root)
{
// return if the tree is empty
if (root == null) {
return;
}
// create an empty queue and enqueue the root node
Queue<Node> queue = new ArrayDeque<>();
queue.add(root);
// to store the current node
Node curr = null;
// loop till queue is empty
while (!queue.isEmpty())
{
// calculate the total number of nodes at the current level
int size = queue.size();
int i = 0;
// process every node of the current level and enqueue their
// non-empty right and right child
while (i++ < size)
{
curr = queue.poll();
// if this is the last node of the current level, print it
if (i == size) {
System.out.print(curr.key + " ");
}
if (curr.left != null) {
queue.add(curr.left);
}
if (curr.right != null) {
queue.add(curr.right);
}
}
}
}
public static void main(String[] args) {
Node root = BuildTree();
printRightView(root);
}
}
/*
TEST CASES:
For Above test case example
Output: 1 3 6 8
Note: -1 denote a Null Node for given Input.
1.
Input: 20 4 1 64 -1 -1 -1 8 -1 -1 7 34 -1 32 -1 -1 -1
Output: 20 7 34 32
Explanation: The tree will look like this
20 <----
/ \
4 7 <----
/ \ /
1 8 34 <----
/ \
64 32 <----
2.
Input: 10 7 8 -1 -1 9 -1 -1 15 18 -1 -1 19 -1 -1
Output: 10 15 19
Explanation: The tree will look like this
10 <----
/ \
7 15 <----
/ \ / \
8 9 18 19 <----
The TIME COMPLEXITY of above solution is O(N) and
SPACE COMPLEXITY is also O(N) ,where N is the Number of nodes in the Tree.
*/