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

84. 柱状图中最大的矩形

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

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

示例 1:

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

示例 2:

复制代码
输入: heights = [2,4]
输出: 4
思路:

/*

单调递减栈

遍历到的数组元素大于或等于栈顶元素,压入栈

遍历到的数组元素小于栈顶元素,取出栈顶元素为middle,st.pop(),heights[i] = right; left = st.top();

h = height[middle];

w = i-st.top()-1;

遍历到的数组元素小于栈顶元素的判断是持续性的判断

result = max(h*w,result);

*/

代码:
cpp 复制代码
class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        /*
            单调递减栈
            遍历到的数组元素大于或等于栈顶元素,压入栈
            遍历到的数组元素小于栈顶元素,取出栈顶元素为middle,st.pop(),heights[i] = right; left = st.top();
            h = height[middle];
            w = i-st.top()-1;
            遍历到的数组元素小于栈顶元素的判断是持续性的判断
            result = max(h*w,result); 
        */
        int result = 0;
        stack<int>st;
        st.push(0);
        heights.insert(heights.begin(),0);
        heights.push_back(0);
        for(int i = 1;i<heights.size();i++)
        {
            if(heights[i]>heights[st.top()])
            {
                st.push(i);
            }
            else if(heights[i]==heights[st.top()])
            {
                st.push(i);
            }
            else{
                while(!st.empty()&&heights[i]<heights[st.top()])
                {
                    int middle = st.top();
                    st.pop();
                    if(!st.empty())
                    {int right = i;
                    int left = st.top();
                    int h = heights[middle];
                    int w = right-left-1;
                    result = max(result,h*w);
                    }
                }
            }
            st.push(i);
        }
        return result;
    }
};

还有很多瑕疵,还需继续坚持!

相关推荐
web_1553427465638 分钟前
性能巅峰对决:Rust vs C++ —— 速度、安全与权衡的艺术
c++·算法·rust
9毫米的幻想40 分钟前
【Linux系统】—— 冯诺依曼体系结构与操作系统初理解
linux·运维·服务器·c语言·c++
Mr.Wang8091 小时前
条款23:宁以non-member、non-friend替换member函数
开发语言·c++
以卿a2 小时前
C++ 模板初阶
开发语言·c++
计算机小白一个7 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^8 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
黑不溜秋的8 小时前
C++ 设计模式 - 策略模式
c++·设计模式·策略模式
大数据追光猿10 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!10 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉10 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode