【LeetCode热题100(99/100)】柱状图中最大的矩形

题目地址: 链接

根据题目易知,想要形成矩形,至少有一个值是完全使用的,所以可以利用单调栈记录每个值的可扩善(左右任意一侧)的最远距离。

最终,根据每个值最远可扩善距离 * height[i],循环比较完毕后即可获取最大矩形面积

TS 复制代码
function largestRectangleArea(heights: number[]): number {
    const n = heights.length;
    
    const dpLeft = new Array(n).fill(0);
    const dpRight= new Array(n).fill(0);

    const stk = [];
    for(let i = 0; i < n; i ++) {
        let [num, idx] = [0, -1];
        while(stk.length && stk[stk.length - 1][0] >= heights[i]) {
            [num, idx] = stk.pop();
        }
        if(stk.length === 0) dpLeft[i] = i;
        else dpLeft[i] = i - stk[stk.length - 1][1] - 1;
        stk.push([heights[i], i]); 
    }


    let ans = 0;
    stk.length = 0;
    for(let i = n - 1; i >= 0; i --) {
        let [num, idx] = [0, n];
        while(stk.length && stk[stk.length - 1][0] >= heights[i]) {
            [num, idx] = stk.pop();
        }
        if(stk.length === 0) dpRight[i] = n - i - 1;
        else dpRight[i] = stk[stk.length - 1][1] - i - 1;
        stk.push([heights[i], i]); 

        ans = Math.max((dpLeft[i] + dpRight[i] + 1) * heights[i], ans);
    }

    return ans;
};
相关推荐
灵感__idea4 小时前
Hello 算法:众里寻她千“百度”
前端·javascript·算法
Wect13 小时前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP1 天前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱1 天前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub2 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP2 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试