leetcode 84 单调栈

这个题目的核心在于,当小柱子出现时,长柱子的结果立马可以被确定,可以归类为,找右边第一个小于自己的元素,从而规约到单调栈解法。

cpp 复制代码
typedef pair<int, int> P;

class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        int ans = 0;
        vector<P> st{P(-1, -1)};
        heights.push_back(-1);
        int n = heights.size();

        for(int i=0;i<n;i++)
        {
            int h = heights[i];
            int mi = i;
            while(h < st.back().first)
            {
                ans = max(ans, st.back().first*(i-st.back().second));
                mi = st.back().second;
                st.pop_back();
            }
            st.push_back(P(h, mi));
        }

        return ans;
    }
};
相关推荐
北顾笙98033 分钟前
day38-数据结构力扣
数据结构·算法·leetcode
m0_6294947334 分钟前
LeetCode 热题 100-----14.合并区间
数据结构·算法·leetcode
xin_nai38 分钟前
LeetCode热题100(Java)(5)普通数组
算法·leetcode·职场和发展
旖-旎1 小时前
深搜练习(组合)(5)
c++·算法·深度优先·力扣
fzil0011 小时前
自动投递简历 + 面试进度跟踪
人工智能·面试·职场和发展
@小码农1 小时前
2026年3月Scratch图形化编程等级考试一级真题试卷
开发语言·数据结构·c++·算法
其实防守也摸鱼1 小时前
面试常问问题总结--护网蓝队方向
网络·笔记·安全·面试·职场和发展·护网·初级蓝队
Wect2 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·算法·typescript
糖果店的幽灵2 小时前
决策树详解与sklearn实战
算法·决策树·sklearn
Lewiis2 小时前
趣谈排序算法
算法·排序算法