84. 柱状图中最大的矩形
https://leetcode.cn/problems/largest-rectangle-in-histogram/
理解题意:最大矩形,也就是相邻min的宽度乘以高度。
整体还是好难想到,看了讲解照着写了一下。
class Solution {
public int largestRectangleArea(int[] heights) {
Stack<Integer> st = new Stack<Integer>();
int [] newHeights = new int[heights.length + 2];
newHeights[0] = 0;
newHeights[newHeights.length - 1] = 0;
for (int index = 0; index < heights.length; index++){
newHeights[index + 1] = heights[index];
}
heights = newHeights;
st.push(0);
int result = 0;
for (int i = 1; i < heights.length; i++) {
while (heights[i] < heights[st.peek()]) {
int mid = st.peek();
st.pop();
int left = st.peek();
int right = i;
int w = right - left - 1;
int h = heights[mid];
result = Math.max(result, w * h);
}
st.push(i);
}
return result;
}
}
今天就结束啦,但是还需要继续复习,复习进度没有跟上~