C++ | Leetcode C++题解之第84题柱状图中最大的矩形

题目:

题解:

class Solution {
public:
    int largestRectangleArea(vector<int>& heights) {
        int n = heights.size();
        vector<int> left(n), right(n, n);
        
        stack<int> mono_stack;
        for (int i = 0; i < n; ++i) {
            while (!mono_stack.empty() && heights[mono_stack.top()] >= heights[i]) {
                right[mono_stack.top()] = i;
                mono_stack.pop();
            }
            left[i] = (mono_stack.empty() ? -1 : mono_stack.top());
            mono_stack.push(i);
        }
        
        int ans = 0;
        for (int i = 0; i < n; ++i) {
            ans = max(ans, (right[i] - left[i] - 1) * heights[i]);
        }
        return ans;
    }
};

相关推荐

  1. LeetCode 84. 矩形

    2024-05-12 07:48:03       15 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-05-12 07:48:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-12 07:48:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-12 07:48:03       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-12 07:48:03       20 阅读

热门阅读

  1. Node.js -- 会话控制

    2024-05-12 07:48:03       9 阅读
  2. iOS 如何让超出父视图的部分响应事件

    2024-05-12 07:48:03       12 阅读
  3. 电商平台遭遇DDOS、CC攻击有什么防护方案

    2024-05-12 07:48:03       9 阅读
  4. Lucene 英文词根处理

    2024-05-12 07:48:03       11 阅读
  5. 十分钟“手撕”内部类+static在内部类的使用

    2024-05-12 07:48:03       11 阅读
  6. react经验15:拖拽排序组件dnd-kit的使用经验

    2024-05-12 07:48:03       9 阅读
  7. vue.js 介绍

    2024-05-12 07:48:03       9 阅读
  8. React Router DOM BrowserRouter

    2024-05-12 07:48:03       10 阅读
  9. Pycharm所有快捷键的使用

    2024-05-12 07:48:03       9 阅读
  10. 【DevOps】Linux 网络命令netstat详解

    2024-05-12 07:48:03       12 阅读
  11. ensp简单ac+ap+sta无线配置和脚本

    2024-05-12 07:48:03       8 阅读
  12. ubuntu删除opencv

    2024-05-12 07:48:03       8 阅读
  13. 华为OD介绍

    2024-05-12 07:48:03       10 阅读