【算法五十六】84. 柱状图中最大的矩形

84. 柱状图中最大的矩形 - 力扣(LeetCode)

单调栈:

java 复制代码
class Solution {
    public int largestRectangleArea(int[] heights) {
        //单调栈
        int n = heights.length;
        int[] newHeights = new int[n+2];
        //加哨兵0,第一个0是为了防止栈空,最后一个0是弹出所有的数
        for(int i = 0;i<n;i++){
            newHeights[i+1] = heights[i];
        }
        int maxArea = 0;
        //存下标,因为要算width,需要用到下标
        Deque<Integer> stack = new ArrayDeque<>();

        for(int i = 0;i<n+2;i++){
            while(!stack.isEmpty() && newHeights[i]<newHeights[stack.peek()]){
                int mid = stack.pop();
                int height = newHeights[mid];
                int width = i-stack.peek()-1;
                maxArea = Math.max(maxArea,height*width);
            }
            stack.push(i);
        }
        return maxArea;
    }
}

时间复杂度:O(N)

空间复杂度:O(N)

相关推荐
fie88891 小时前
matlab打靶法求解两点边值优化问题
开发语言·算法·matlab
不做无法实现的梦~1 小时前
常见工程分析软件
stm32·嵌入式硬件·算法
hetao17338371 小时前
2026-05-28~06-02 hetao1733837 的刷题记录
c++·算法
ZhengEnCi1 小时前
O08-单写线程与单读线程冲突分析
算法
仍然.2 小时前
算法题目---优先级队列
算法
一个爱编程的人2 小时前
图的相关概念
c++·算法·图论
迈巴赫车主2 小时前
贪心算法
算法·贪心算法
星马梦缘2 小时前
死锁与进程资源分配问题的解法
算法·操作系统·深度优先·死锁
爱炼丹的James2 小时前
第四章 数学知识
算法