算法刷题Day 60 柱状图中的最大矩阵

Day 60 单调栈

84. 柱状图中最大的矩形

暴力解法

超时了

分别找出当前位置左边第一个 比自己小的索引(的后一个位置)和右边第一个比自己小的索引(的前一个位置),这个范围之内,就是以当前位置的高度所能达到的最大宽度。

cpp 复制代码
class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        int maxArea = 0;

        for (int i = 0; i < heights.size(); ++i)
        {
            int leftLowerIdx = i, rightLowerIdx = i;

            for (int j = i; j >= 0; --j)
            {
                if (heights[j] < heights[i])
                {
                    break;
                }
                else
                {
                    leftLowerIdx = j;
                }
            }

            for (int j = i; j < heights.size(); ++j)
            {
                if (heights[j] < heights[i])
                {
                    break;
                }
                else
                {
                    rightLowerIdx = j;
                }
            }

            int area = heights[i] * (rightLowerIdx - leftLowerIdx + 1);
            if (area > maxArea)
            {
                maxArea = area;
            }
        }

        return maxArea;
    }
};

双指针

cpp 复制代码
class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        vector<int> leftLower(heights.size(), 0);
        leftLower[0] = -1; // 注意这个地方是 - 1,否则会导致死循环

        for (int i = 1; i < heights.size(); ++i)
        {
            int t = i - 1; 
            while (t >= 0 && heights[t] >= heights[i])
            {
                t = leftLower[t];
            }
            leftLower[i] = t;
        }

        vector<int> rightLower(heights.size(), 0);
        rightLower.back() = heights.size(); // 注意这个地方的值为heights.size(),否则会导致死循环

        for (int i = heights.size() - 2; i >= 0; --i)
        {
            int t = i + 1;
            while (t < heights.size() && heights[t] >= heights[i])
            {
                t = rightLower[t];
            }
            rightLower[i] = t;
        }

        int maxArea = 0;
        for (int i = 0; i < heights.size(); i++)
        {
            int area = heights[i] * (rightLower[i] - leftLower[i] - 1);
            if (area > maxArea)
            {
                maxArea = area;
            }
        }

        return maxArea;
    }
};

单调栈

有了接雨水那道题的经验,这一道题可以模仿着做出了

cpp 复制代码
class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        int maxArea = 0;
        stack<int> incStk;
        incStk.push(-1);
        heights.push_back(-1);

        for (int i = 0; i < heights.size(); ++i)
        {
            while (incStk.top() != -1 && heights[incStk.top()] > heights[i])
            {
                int idx = incStk.top();
                incStk.pop();
                int w = i - incStk.top() - 1;
                int area = heights[idx] * w;
                if (area > maxArea)
                {
                    maxArea = area;
                }
            }
            incStk.push(i);
        }

        return maxArea;
    }
};
相关推荐
碧海银沙音频科技研究院7 分钟前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
csdn_aspnet1 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
m0_629494734 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户4 小时前
用队列实现栈
数据结构·算法
做人求其滴4 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
daad7774 小时前
记一组无人机IMU传感器数据
算法
计算机安禾4 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法
小O的算法实验室4 小时前
2026年KBS,流形感知强化学习差分进化算法+不规则3D无人机路径规划,深度解析+性能实测
算法·智能算法·智能算法改进
玖釉-5 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法