forked from anitaa1990/Android-Cheat-sheet
-
Notifications
You must be signed in to change notification settings - Fork 0
/
NthHighestBST.java
106 lines (81 loc) · 3.02 KB
/
NthHighestBST.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
package trees;
public class NthHighestBST {
/*
* Find nth highest node in a Binary Search Tree(BST)
*
* Runtime Complexity:
* Linear, O(n)
*
* Memory Complexity:
* O(h)
*
* In-order traversal of BST is always sorted in ascending order.
* To find the nth highest node, we will need to scan the tree in descending order that can achieve by doing reverse inorder traversal.
* The inorder traversal is normally LVR i.e. Left - Visit - Right. Reverse inorder traversal will be RVL i.e. Right - Visit - Left.
* While doing so, we keep a count of nodes seen so far. Once the count reaches n, that is the node to return.
*
* */
private static class Node {
private int data;
private Node left, right;
Node(int item) {
data = item;
left = right = null;
}
public int getData() {
return data;
}
public Node getLeft() {
return left;
}
public Node getRight() {
return right;
}
}
private Node root1;
protected int currentCount = 0;
protected Node findNthHighestInBst(Node node, int n) {
if (node == null) {
return null;
}
Node result = findNthHighestInBst(node.right, n);
if (result != null) {
return result;
}
currentCount++;
if (n == currentCount) {
return node;
}
result = findNthHighestInBst(node.left, n);
if (result != null) {
return result;
}
return null;
}
public static void main(String[] argv) {
NthHighestBST nthHighestBST = new NthHighestBST();
nthHighestBST.root1 = new Node(100);
nthHighestBST.root1.left = new Node(50);
nthHighestBST.root1.right = new Node(200);
nthHighestBST.root1.left.left = new Node(25);
nthHighestBST.root1.left.right = new Node(75);
nthHighestBST.root1.right.left = new Node(125);
nthHighestBST.root1.right.right = new Node(350);
int n = 2;
nthHighestBST.currentCount = 0;
Node nth_highest_node = nthHighestBST.findNthHighestInBst(nthHighestBST.root1, n);
System.out.println(String.format(" - %d highest node is %d", n, nth_highest_node.data));
n = 1;
nthHighestBST.currentCount = 0;
nth_highest_node = nthHighestBST.findNthHighestInBst(nthHighestBST.root1, n);
System.out.println(String.format(" - %d highest node is %d", n, nth_highest_node.data));
n = 5;
nthHighestBST.currentCount = 0;
nth_highest_node = nthHighestBST.findNthHighestInBst(nthHighestBST.root1, n);
System.out.println(String.format(" - %d highest node is %d", n, nth_highest_node.data));
n = 30;
nthHighestBST.currentCount = 0;
nth_highest_node = nthHighestBST.findNthHighestInBst(nthHighestBST.root1, n);
System.out.println(String.format(" - %d highest node is %d", n, nth_highest_node));
}
}