-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsubarray_minimum.java
More file actions
31 lines (27 loc) · 912 Bytes
/
subarray_minimum.java
File metadata and controls
31 lines (27 loc) · 912 Bytes
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
public int sumSubarrayMins(int[] arr) {
final int kMod = 1_000_000_007;
final int n = arr.length;
long ans = 0;
// prevMin[i] := index k s.t. arr[k] is the previous minimum in arr[:i]
int[] prevMin = new int[n];
// nextMin[i] := index k s.t. arr[k] is the next minimum in arr[i + 1:]
int[] nextMin = new int[n];
Deque<Integer> stack = new ArrayDeque<>();
Arrays.fill(prevMin, -1);
Arrays.fill(nextMin, n);
for (int i = 0; i < arr.length; ++i) {
while (!stack.isEmpty() && arr[stack.peek()] > arr[i]) {
final int index = stack.pop();
nextMin[index] = i;
}
if (!stack.isEmpty())
prevMin[i] = stack.peek();
stack.push(i);
}
for (int i = 0; i < arr.length; ++i) {
ans += (long) arr[i] * (i - prevMin[i]) * (nextMin[i] - i);
ans %= kMod;
}
return (int) ans;
}
}