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

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

相关推荐
星释5 分钟前
Rust 练习册 :Luhn Trait与Trait实现
网络·算法·rust
ゞ 正在缓冲99%…15 分钟前
leetcode1770.执行乘法运算的最大分数
java·数据结构·算法·动态规划
abcefg_h24 分钟前
链表算法---基本算法操作(go语言版)
算法·链表·golang
小O的算法实验室24 分钟前
2022年IEEE TITS SCI2区TOP,基于切线交点和目标引导策略的无人机自主路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
007php00734 分钟前
大厂深度面试相关文章:深入探讨底层原理与高性能优化
java·开发语言·git·python·面试·职场和发展·性能优化
Mr_Oak1 小时前
【multi-model】moco系列&SimCLR&BEiT
人工智能·深度学习·神经网络·算法·计算机视觉·transformer·对比学习
尼古拉斯·纯情暖男·天真·阿玮1 小时前
动态规划——子序列问题
java·算法·动态规划
立志成为大牛的小牛2 小时前
数据结构——四十、折半查找(王道408)
数据结构·学习·程序人生·考研·算法
孙同学_2 小时前
面试题 16.25. LRU 缓存
leetcode·缓存
王哈哈^_^2 小时前
【完整源码+数据集】蓝莓数据集,yolo11蓝莓成熟度检测数据集 3023 张,蓝莓成熟度数据集,目标检测蓝莓识别算法系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·ai·视觉检测