算法训练营第63天|LeetCode 84.柱状图中最大的矩形

完结!撒花!

LeetCode 84.柱状图中最大的矩形

题目链接:

LeetCode 84.柱状图中最大的矩形

代码:

cpp 复制代码
class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        heights.insert(heights.begin(),0);
        heights.push_back(0);
        int size = heights.size();
        stack<int>st;
        int result = 0;
        st.push(0);
        for(int i=1;i<size;i++){
            if(heights[i]>=heights[st.top()]) st.push(i);
            else{
                while(!st.empty() && heights[i]<heights[st.top()]){
                    int mid = st.top();
                    st.pop();
                    if(!st.empty()){
                        int right = i;
                        int left = st.top();
                        int w = right - left - 1;
                        result = max(result, w*heights[mid]);
                    }
                }
                st.push(i);
            }
        }
        return result;
    }
};
相关推荐
HelloDam6 分钟前
leetcode59.螺旋矩阵II 很绕?理不清?一文给你快速理清思路
java·后端·leetcode
徽京人8 分钟前
第八届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组 购物单
c++·职场和发展·蓝桥杯
前端 贾公子12 分钟前
力扣1338 === 贪心算法解决数组减半问题
算法·leetcode·贪心算法
HelloDam21 分钟前
leetcode28.找出字符串中第一个匹配项的下标,KMP算法保姆级教程(带动图)
java·后端·算法
不是编程家33 分钟前
优选算法第七讲:分治
算法
LuckyLay40 分钟前
LeetCode算法题(Go语言实现)_36
算法·leetcode·golang
S01d13r42 分钟前
LeetCode 解题思路 33(Hot 100)
javascript·算法·leetcode
阿巴~阿巴~1 小时前
蓝桥杯 C/C++ 组历届真题合集速刷(二)
c语言·c++·算法·蓝桥杯
IOsetting1 小时前
图像处理中的 Gaussina Blur 和 SIFT 算法
图像处理·人工智能·算法
Cloud_.2 小时前
蓝桥杯-蓝桥幼儿园(并查集)
职场和发展·蓝桥杯