当前位置: 首页 > news >正文

LeetCode 84. 柱状图中最大的矩形(困难)

 题目描述  

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

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

示例

示例 1:

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

示例 2:

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

解法

1.暴力(跑不通所有样例)

解题思路

      如果我们想暴力解决这个问题,需要遍历heights数组每个元素,分别从i位置向左和向右查找比heights[i]小元素的坐标,这样以heights[i]为高矩形的宽就是right-left-1,然后计算出不同高矩形的面积,取最大值。这种做法的时间复杂度是O(n^2),大概率跑不通所有样例。

class Solution {
public:int largestRectangleArea(vector<int>& heights) {int n = heights.size();int s_max = 0;for(int i = 0;i < n;i ++){int left = i,right = i;while(left >= 0 && heights[left] >= heights[i]) left --;while(right < n && heights[right] >= heights[i]) right ++;int s = (right - left  - 1) * heights[i];s_max = max(s,s_max);}return s_max;}
};

        时间复杂度O(N^2),空间复杂度O(1)

2.单调栈

解题思路:

        与暴力解法中为每个柱子向左右双向扩展寻找边界相比,单调栈解法的核心思想是利用栈的单调递增性质,在单向遍历过程中动态记录边界信息:当遇到较矮柱子时,栈中较高柱子的右边界被确定并弹出,而当前柱子的左边界就是弹出后栈顶的柱子,这样通过维护一个高度递增的栈结构,在O(n)时间内就完成了所有柱子左右边界的计算。

class Solution {
public:int largestRectangleArea(vector<int>& heights) {int n = heights.size();vector<int> left(n,-1); // 左边界数组,初始为-1(左边界在数组外)vector<int> right(n,n); // 右边界数组,初始为n(右边界在数组外)stack<pair<int,int>> st; // 单调栈,存储{高度, 索引}int s = 0,s_max = 0;for(int i = 0;i < n;i ++){while(!st.empty() && heights[i] < st.top().first){right[st.top().second] = i; // 当前柱子是栈顶柱子的右边界st.pop();}if(!st.empty()){left[i] = st.top().second; // 栈顶柱子是当前柱子的左边界}st.push({heights[i],i}); //将当前柱子压入栈中,保持栈的单调递增性}//计算最大面积for(int i = 0;i < n;i ++){s = (right[i] - left[i] - 1) * heights[i];s_max = max(s_max,s);}return s_max;}
};

        时间复杂度O(N),空间复杂度O(N)

http://www.dtcms.com/a/597852.html

相关文章:

  • YOLOv2算法详解(下篇):细节打磨与性能突破的终极密码
  • 算法 day 51
  • BI二维数据可视化大屏升级三维可视化大屏:前端开发者下一个内卷赛道
  • 插补算法(逐点比较法)+PWM配置操作
  • 唐山网站制作app新郑市网站建设
  • 买完阿里云域名如何做网站网站商业授权
  • QEMU 使用 Open vSwitch网桥连接虚拟机网络
  • 充气泵方案:充气泵与汽车的关系
  • 北京P2P公司网站建设网站建设合同 模板 下载
  • 贴片机编程:提高生产效率与精度的关键技术 | 贴片机编程技巧与注意事项详解
  • 深度学习_三层神经网络传播案例(L0->L1->L2)
  • 营销类网站建设需要注意的问题国家信用信息公示系统官网山东
  • 第四章:C# 面向对象编程详解:从类与对象到完整项目实践
  • DDoS防护:为企业业务保驾护航的高可用盾牌
  • 企业产品做哪个网站推广好建筑培训课程有哪些
  • 模版 c++
  • LLaMA Factory微调大模型
  • UaGateway构建高可用OPC UA架构:实现冗余通信与数据聚合
  • Linux之vmlinux文件段布局和arm64 的链接脚本vmlinux.lds.S分析
  • C#6、三种主要的错误类型是什么
  • 使用Selenium进行网页自动化
  • 论坛网站建设推广优化wordpress主题下载资源
  • 网站推广文章范例在哪里查企业信息最准确
  • MCP驱动的Rgentic RRG(向量数据库+网络搜索)
  • 网站漏洞怎么修复上海劳务市场招聘信息查询
  • 异常的分类
  • 做时时网站要多少钱用虚拟机做网站服务器
  • 任性动图教程2 -如何让诗词生成动图
  • 零基础学JAVA--Day29( StringBuffer+ StringBuilder)
  • 做源码演示的网站果洛wap网站建设多少钱