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;
    }
};
相关推荐
liuyao_xianhui2 小时前
递归_反转链表_C++
java·开发语言·数据结构·c++·算法·链表·动态规划
CoderCodingNo2 小时前
【GESP】C++七级考试大纲知识点梳理 (3) 图论基础与遍历算法
c++·算法·图论
深蓝轨迹2 小时前
LeetCode105. 从前序与中序遍历序列构造二叉树
数据结构·算法
TracyCoder1232 小时前
LeetCode Hot100(63/100)——31. 下一个排列
数据结构·算法·leetcode
智者知已应修善业2 小时前
【不用第三变量交换2个数】2024-10-18
c语言·数据结构·c++·经验分享·笔记·算法
会编程的土豆2 小时前
c语言时间戳从入门到精通
linux·c语言·算法
所谓伊人,在水一方3332 小时前
【机器学习精通】第2章 | 优化算法深度解析:从梯度下降到自适应优化器
人工智能·python·算法·机器学习·信息可视化
Storynone2 小时前
【Day24】LeetCode:122. 买卖股票的最佳时机 II,55. 跳跃游戏,45. 跳跃游戏II,1005. K次取反后最大化的数组和
python·算法·leetcode
滴滴答滴答答2 小时前
机考刷题之 17&18&19&20&21&22 LeetCode 1248&121&43&93&62&63
算法·leetcode·职场和发展