给定一个整数数组 A
,找到 min(B)
的总和,其中 B
的范围为 A
的每个(连续)子数组。
由于答案可能很大,因此返回答案模 10^9 + 7
。
示例:
输入:[3,1,2,4]
输出:17
解释:
子数组为 [3],[1],[2],[4],[3,1],[1,2],[2,4],[3,1,2],[1,2,4],[3,1,2,4]。
最小值为 3,1,2,4,1,1,2,1,1,1,和为 17。
提示:
1 <= A <= 30000
1 <= A[i] <= 30000
class Solution {
public:
int sumSubarrayMins(vector<int>& A) {
int len=A.size();
long long result=0;
long long mod=1000000007;
for(int i=0;i<len;i++)
{
int l;
for(l=i-1;l>=0&&A[i]<A[l];l--);
int r;
for(r=i+1;r<len&&A[i]<=A[r];r++);
result=result+(i-l)*(r-i)*A[i];
}
result=result%mod;
return result;
}
};