-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathsum-of-subarray-minimums.cpp
45 lines (39 loc) · 1.29 KB
/
sum-of-subarray-minimums.cpp
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
class Solution {
const int mod = 1e9 + 7;
public:
int sumSubarrayMins(vector<int>& arr) {
int n = arr.size();
int area[n][2];
// ple
stack<int> s;
for(int i = 0; i < n; i++){
while(!s.empty() and arr[s.top()] > arr[i]) s.pop();
if(s.empty())
area[i][0] = 0;
else
area[i][0] = s.top() + 1;
s.push(i);
}
// nle
stack<int> st;
for(int i = n - 1; i >= 0; i--){
while(!st.empty() and arr[st.top()] >= arr[i]) st.pop();
if(st.empty())
area[i][1] = n - 1;
else
area[i][1] = st.top() - 1;
st.push(i);
}
int sum = 0;
for(int i = 0; i < n; i++){
int lo = area[i][0], hi = area[i][1];
// cout << i << " " << lo << " " << hi << endl;
long prod = ((i - lo + 1) % mod * (hi - i + 1) % mod) % mod;
prod = (prod % mod * arr[i] % mod) % mod;
sum = (sum + prod) % mod;
// sum = (sum + ((arr[i] % mod * ((i - lo + 1) * (hi - i + 1)) % mod)) % mod) % mod;
}
cout << mod << endl;
return sum ;
}
};