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

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

相关推荐
少许极端1 分钟前
算法奇妙屋(三十一)-递归、回溯与剪枝的综合问题 4
算法·剪枝·回溯·递归
mjhcsp1 分钟前
C++随机调整(Random Adjustment):优化算法的核心随机策略
java·c++·算法
Yupureki1 分钟前
《C++实战项目-高并发内存池》6.内存释放流程
c语言·开发语言·数据结构·c++·算法·哈希算法
badhope2 分钟前
一命速通蓝桥杯全攻略
开发语言·前端·人工智能·python·职场和发展·蓝桥杯·github
charlie1145141914 分钟前
嵌入式现代C++开发——三路比较运算符
开发语言·c++·学习·算法·嵌入式·编程指南
2401_900151544 分钟前
C++编译期正则表达式
开发语言·c++·算法
倾心琴心5 分钟前
【agent辅助pcb routing coding学习】实践1 kicad pcb 格式讲解
算法·agent·pcb·eda·routing
仙俊红6 分钟前
LeetCode493周赛T3,前后缀分解
数据结构·算法·leetcode
_日拱一卒8 分钟前
LeetCode(力扣):二叉树的前序遍历
java·数据结构·算法·leetcode
倾心琴心9 分钟前
【agent辅助pcb routing coding学习】实践5 kicad类按类别理解
算法·agent·pcb·eda·routing