【Hot 100 刷题计划】 LeetCode 84. 柱状图中最大的矩形 | C++ 两次单调栈基础扫法

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

📌 题目描述

题目级别:困难

给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。

求在该柱状图中,能够勾勒出来的矩形的最大面积。

  • 示例 1:
    输入:heights = [2,1,5,6,2,3]
    输出:10
    解释:最大的矩形为高度为 5 和 6 的两根柱子组成的矩形,面积为 5 * 2 = 10

💡 破题思路:三次遍历寻找左右边界

要求出最大矩形,我们可以转换思维:以每一根柱子的高度为准,它向左向右最多能延伸多宽?

延伸的极限在哪里?就在于遇到了第一个比它矮的柱子

所以,我们只需要利用单调递增栈

  1. 从左往右扫一遍,找到每个柱子左侧第一个比它矮的位置,存入 l 数组。
  2. 从右往左扫一遍,找到每个柱子右侧第一个比它矮的位置,存入 r 数组。
  3. 最后再遍历一次,以每个柱子为高,计算宽度 r[i] - l[i] - 1,求出最大面积。

⚠️ 面试避坑点:

很多题解喜欢用 int l[n], r[n] 这种变长数组(VLA),这在严格的 C++ 标准下是会编译报错的。在大厂手撕代码时,遇到动态长度的数组,请务必使用 vector<int>


💻 C++ 代码实现 (规范版)

cpp 复制代码
class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        int n = heights.size();
        stack<int> st;
        // 规范写法:使用 vector 而不是 VLA
        vector<int> l(n), r(n);
        
        // 1. 寻找左侧第一个比自己矮的柱子
        for (int i = 0; i < n; i ++ )
        {
            while (st.size() && heights[st.top()] >= heights[i]) st.pop();
            // 如果栈空了,说明左边没有比自己矮的,边界延展到极左 -1
            l[i] = st.empty() ? -1 : st.top();
            st.push(i);
        }

        // 清空栈,准备第二次遍历
        while (st.size()) st.pop();

        // 2. 寻找右侧第一个比自己矮的柱子
        for (int i = n - 1; i >= 0; i -- )
        {
            while (st.size() && heights[st.top()] >= heights[i]) st.pop();
            // 如果栈空了,说明右边没有比自己矮的,边界延展到极右 n
            r[i] = st.empty() ? n : st.top();
            st.push(i);
        }

        int res = 0;

        // 3. 结算每一个柱子能勾勒的最大面积
        for (int i = 0; i < n; i ++ )
        {
            res = max(res, (r[i] - l[i] - 1) * heights[i]);
        }

        return res;
    }
};
相关推荐
小苗卷不动2 小时前
OJ刷题之栈和排序(中等)
c++
沫璃染墨2 小时前
重生之我要手写 C++ list:从底层结构到 const 迭代器与迭代器失效全解
开发语言·c++
C雨后彩虹2 小时前
文件目录大小
java·数据结构·算法·华为·面试
0南城逆流02 小时前
【技术点】嵌入式技术考点三:数据结构
java·数据结构·算法
罗湖老棍子2 小时前
Beads(信息学奥赛一本通- P1461) [POI 2010] KOR-Beads(洛谷-P3498)
算法·字符串·哈希
paeamecium2 小时前
【PAT甲级真题】- Favorite Color Stripe (30)
数据结构·c++·算法·pat
DeepModel2 小时前
机器学习数据预处理:特征构造
人工智能·学习·算法·机器学习
棋子入局2 小时前
C语言实现消消乐游戏(6)
c语言·算法·游戏
郭涤生2 小时前
C++ 线程同步复习
开发语言·c++