【力扣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;
    }
};

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

相关推荐
MeyrlNotFound1 分钟前
杂谈:抖音双塔召回模型:亿级内容分发的数学魔法
算法
不爱学英文的码字机器6 分钟前
隐私计算的崛起:数据安全的未来守护者
服务器·算法
菜就多练,以前是以前,现在是现在9 分钟前
Codeforces Round 1000 (Div. 2)
数据结构·c++·算法
Swift社区14 分钟前
Swift 解 LeetCode 250:搞懂同值子树,用递归写出权限系统检查器
开发语言·leetcode·swift
爪娃侠27 分钟前
LeetCode热题100记录-【矩阵、图论】
leetcode·矩阵·图论
Lenyiin28 分钟前
2181、合并零之间的节点
c++·算法·leetcode·链表
gentle_ice29 分钟前
找树左下角的值(DFS 深度优先搜索)| LeetCode 513
数据结构·算法·leetcode·深度优先
菜鸡中的奋斗鸡→挣扎鸡2 小时前
总结:查找子字符串出现次数
c++·算法·蓝桥杯
刃神太酷啦2 小时前
基础算法篇(4)(蓝桥杯常考点)—数据结构(进阶)
数据结构·c++·算法·蓝桥杯·哈希算法·蓝桥杯c++组
Zz_waiting.2 小时前
多线程代码案例(定时器) - 3
开发语言·算法·安全·javaee