forked from IDeserve/learn
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLongestIncreasingSubsequence.java
60 lines (48 loc) · 1.27 KB
/
LongestIncreasingSubsequence.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
package questions.virendra;
public class LongestIncreasingSubsequence {
public static void LIS(int X[])
{
int parent[]= new int[X.length]; //Tracking the predecessors/parents of elements of each subsequence.
int increasingSub[]= new int[X.length + 1]; //Tracking ends of each increasing subsequence.
int length = 0; //Length of longest subsequence.
for(int i=0; i<X.length; i++)
{
//Binary search
int low = 1;
int high = length;
while(low <= high)
{
int mid = (int) Math.ceil((low + high)/2);
if(X[increasingSub[mid]] < X[i])
low = mid + 1;
else
high = mid - 1;
}
int pos = low;
//update parent/previous element for LIS
parent[i] = increasingSub[pos-1];
//Replace or append
increasingSub[pos] = i;
//Update the length of the longest subsequence.
if(pos > length)
length=pos;
}
//Generate LIS by traversing parent array
int LIS[] = new int[length];
int k = increasingSub[length];
for(int j=length-1; j>=0; j--)
{
LIS[j] = X[k];
k = parent[k];
}
for(int i=0; i<length; i++)
{
System.out.println(LIS[i]);
}
}
public static void main(String args[])
{
int X[] = {3,1,5,0,6,4,9};
LIS(X);
}
}