forked from indy256/codelibrary
-
Notifications
You must be signed in to change notification settings - Fork 0
/
RmqSparseTable.java
36 lines (32 loc) · 1.2 KB
/
RmqSparseTable.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
package structures;
public class RmqSparseTable {
int[][] rmq;
public RmqSparseTable(int[] a) {
int n = a.length;
rmq = new int[32 - Integer.numberOfLeadingZeros(n)][];
rmq[0] = a.clone();
for (int i = 1; i < rmq.length; i++) {
rmq[i] = new int[n - (1 << i) + 1];
for (int j = 0; j < rmq[i].length; j++) rmq[i][j] = Math.min(rmq[i - 1][j], rmq[i - 1][j + (1 << (i - 1))]);
}
}
public int min(int i, int j) {
int k = 31 - Integer.numberOfLeadingZeros(j - i + 1);
return Math.min(rmq[k][i], rmq[k][j - (1 << k) + 1]);
}
public static void main(String[] args) {
{
RmqSparseTable st = new RmqSparseTable(new int[] {1, 5, -2, 3});
System.out.println(1 == st.min(0, 0));
System.out.println(-2 == st.min(1, 2));
System.out.println(-2 == st.min(0, 2));
System.out.println(-2 == st.min(0, 3));
}
{
RmqSparseTable st = new RmqSparseTable(new int[] {1, 5, -2});
System.out.println(1 == st.min(0, 0));
System.out.println(-2 == st.min(1, 2));
System.out.println(-2 == st.min(0, 2));
}
}
}