arr中任何一个子数组sub,可以算出(sub累加和)*(sub中的最小值),所有子数组中,该值最大是多少?
子数组连续
以i位置来说,在它左边、右边分别找到距离它最近的小于它的数,这个子数组的最小值就是i位置
1、不遍历如何求累加和?
建立一个数组,算前缀和—1到4位置的累加和,用4的前缀和减去1的前缀和
public static int max2(int[] arr) {
int size = arr.length;
int[] sums = new int[size];
sums[0] = arr[0];
//生成前缀和
for (int i = 1; i < size; i++) {
sums[i] = sums[i - 1] + arr[i];
}
int max = Integer.MIN_VALUE;
Stack<Integer> stack = new Stack<Integer>();
for (int i = 0; i < size; i++) {
//大于等于就弹出
while (!stack.isEmpty() && arr[stack.peek()] >= arr[i]) {
int j = stack.pop();
max = Math.max(max, (stack.isEmpty() ? sums[i - 1] : (sums[i - 1] - sums[stack.peek()])) * arr[j]);
}
stack.push(i);
}
while (!stack.isEmpty()) {
int j = stack.pop();
max = Math.max(max, (stack.isEmpty() ? sums[size - 1] : (sums[size - 1] - sums[stack.peek()])) * arr[j]);
}
return max;
}