LeetCode热题100 柱状图中最大的矩形

题目描述

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

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

示例 1:


输入 :heights = [2,1,5,6,2,3]
输出 :10
解释:最大的矩形为图中红色区域,面积为 10

示例 2:


输入 : heights = [2,4]
输出: 4

提示:

1<=heights.length<=1051 <= heights.length <=10^51<=heights.length<=105
0<=heights[i]<=1040 <= heights[i] <= 10^40<=heights[i]<=104

思路

1 我们枚举以i为矩形的高度,最左端和最右端在哪里,也就是宽度,这样每个点为矩形的答案就知道了,取max。

2 以右端为例,必须满足在右端内的所有点的高度都大于等于i点的高度,否则就不能构成以i为高度的矩形。

3 求i的左端点和右端点的问题可以两个单调栈解决,写法见代码。

代码

cpp 复制代码
class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        stack<int>s;
        int n = heights.size();
        vector<int>right(n);
        vector<int>left(n);

        // 枚举以该点高度为答案的最右侧
        for(int i = 0; i < n; ++i)
        {
            while(!s.empty() && heights[s.top()] > heights[i])
            {
                right[s.top()] = i - 1;
                s.pop();            
            }
            s.push(i);
        }
        while(!s.empty())
        {
            right[s.top()] = n - 1;
            s.pop();
        }

        // 枚举以该点高度为答案的最左侧
        for(int i = n - 1; i >= 0; --i)
        {
            while(!s.empty() && heights[s.top()] > heights[i])
            {
                left[s.top()] = i + 1;
                s.pop();            
            }
            s.push(i);
        }
        while(!s.empty())
        {
            left[s.top()] = 0;
            s.pop();
        }

        // 计算答案
        int ans = 0;
        for(int i = 0; i < n; ++i)
        {
            ans = max(ans, (right[i] - left[i] + 1) * heights[i]);
        }

        return ans;
    }
};
相关推荐
ZhengEnCi1 天前
S10-蓝桥杯 17822 乐乐的积木塔
算法
贾斯汀玛尔斯1 天前
每天学一个算法--拓扑排序(Topological Sort)
算法·深度优先
t***5441 天前
如何配置Orwell Dev-C++使用Clang
开发语言·c++
大龄程序员狗哥1 天前
第25篇:Q-Learning算法解析——强化学习中的经典“价值”学习(原理解析)
人工智能·学习·算法
exp_add31 天前
质数相关知识
算法
CoderCodingNo1 天前
【信奥业余科普】C++ 的奇妙之旅 | 13:为什么 0.1+0.2≠0.3?——解密“爆int”溢出与浮点数精度的底层原理
开发语言·c++
小辉同志1 天前
215. 数组中的第K个最大元素
数据结构·算法·leetcode··快速选择
小O的算法实验室1 天前
2025年IEEE TITS,基于矩阵的进化计算+面向无线传感器网络数据收集无人机路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
OidEncoder1 天前
编码器分辨率与机械精度的关系
人工智能·算法·机器人·自动化
memcpy01 天前
LeetCode 2615. 等值距离和【相同元素分组+前缀和;考虑距离和的增量】中等
算法·leetcode·职场和发展