【力扣hot100题】(072)柱状图中的最大矩阵

这绝对是我做过印象最深的算法题之一。(还有是那道盛水最多的贪心题)

当初不知道想了多少个日日夜夜,所幸这道题已经深深的烙印在了我的脑海里。

现在看来也没那么可怕()不过初见确实非常难想到单调栈。

方法如下,确保柱状图中的元素是递增的,当遇到比上一个小的元素就往前遍历所有比当前元素大的元素,每次比较区间围出的矩形,并将遍历的元素的值都变为当前元素,总之要确保柱状图递增。

然后为了处理柱状图真的是一直递增的情况,我们还需要在原本的容器最后加入一个0,确保至少有一次遍历。

cpp 复制代码
class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        int result=heights[0];
        heights.push_back(0);
        for(int i=1;i<heights.size();i++){
            if(heights[i]<heights[i-1]){
                for(int j=i-1;j>=0&&heights[j]>heights[i];j--){
                    result=max(result,(i-j)*heights[j]);
                    heights[j]=heights[i];
                }
            }
        }
        return result;
    }
};

感叹一下当初为了做这题简直费尽心思机关算尽,现在看来也不过如此。

相关推荐
pwn蒸鱼几秒前
leetcode:92. 反转链表 II
算法·leetcode·链表
深念Y4 分钟前
Harness Engineering:我的HomeSense Agent 架构演进
人工智能·算法·架构·智能家居·agent·小爱同学·harness
Imxyk7 分钟前
P9244 [蓝桥杯 2023 省 B] 子串简写
数据结构·c++·算法
colus_SEU8 分钟前
SVM 面试题总结
算法·机器学习·支持向量机
INGNIGHT9 分钟前
373. 查找和最小的 k 对数字(堆priority_queue)
算法
ambition2024213 分钟前
深度优先搜索(DFS)与回溯算法详解:以全排列问题为例
算法·深度优先
Omics Pro13 分钟前
马普所:生命蛋白质宇宙聚类
数据库·人工智能·算法·机器学习·数据挖掘·aigc·聚类
汀、人工智能14 分钟前
[特殊字符] 第106课:旋转图像
数据结构·算法·矩阵·数据库架构·数组·旋转图像
ulias21218 分钟前
leetcode热题 - 2
算法·leetcode·职场和发展
Ivanqhz19 分钟前
SMT(Satisfiability Modulo Theories,基于模理论的可满足性)
人工智能·算法·机器学习