算法修炼Day60|● 84.柱状图中最大的矩形

LeetCode:84.柱状图中最大的矩形

84. 柱状图中最大的矩形 - 力扣(LeetCode)

1.思路

双指针思路,以当前数组为中心,借助两个数组存放当前数柱左右两侧小于当前数柱高度的索引,进行h*w的计算。注意首尾节点的左侧索引和右侧索引需要单独声名为0.

单调栈,在原数组的基础上定义一个新的数组,对其进行首尾节点的扩容。思路延续收集雨水。

2.代码实现
java 复制代码
class Solution {

  public int largestRectangleArea(int[] heights) {

​    Stack<Integer> stack = new Stack<>();

​    // 数组扩容

​    int[] newHeights = new int[heights.length + 2];

​    newHeights[0] = 0;

​    newHeights[newHeights.length - 1] = 0;

​    for (int i = 0; i < heights.length; i++) {

​      newHeights[i + 1] = heights[i];

​    }

​    heights = newHeights; // 改变数组引用

​    stack.add(0);

​    int result = 0;

​    for (int i = 1; i < heights.length; i++) {

​      if (heights[i] > heights[stack.peek()]) { // 入栈

​        stack.add(i);

​      } else if (heights[i] == heights[stack.peek()]) { 

​        stack.pop(); // 弹出

​        stack.add(i); // 入栈

​      } else {

​        while (heights[i] < heights[stack.peek()]) {

​          int mid = stack.peek(); // 当前数值柱子

​          stack.pop();

​          int left = stack.peek();

​          int right = i;

​          int w = right - left - 1;

​          int h = heights[mid];

​          result = Math.max(result, w * h);

​        }

​        stack.add(i);

​      }

​    }

​    return result;

  }

}
3.复杂度分析:

时间复杂度:O(n).

空间复杂度:O(n).符合单调递减的情况时,全部入栈。

相关推荐
joshchen21518 小时前
强化学习基础(赵世钰)第一章
人工智能·深度学习·算法·机器学习·强化学习
小此方19 小时前
Re:从零开始的 C++ STL篇(十二)深度解析哈希函数设计、负载因子调节与两种冲突处理策略
c++·算法·哈希算法
xuhaoyu_cpp_java19 小时前
单调栈(算法)
java·数据结构·经验分享·笔记·学习·算法
诙_19 小时前
C++数据结构--排序算法
数据结构·算法·排序算法
jieyucx19 小时前
Go 切片核心:子切片详解(下篇)
开发语言·算法·golang·切片
CQU_JIAKE19 小时前
5.5【A】
算法
云qq20 小时前
C++ 原子操作
开发语言·c++·算法
xrgs_shz20 小时前
基于轻量化浅层卷积神经网络的手写数字识别
算法·matlab·cnn
计算机安禾20 小时前
【计算机网络】第10篇:距离矢量路由算法——Bellman-Ford方程与RIP协议的特性分析
计算机网络·算法
机器学习之心20 小时前
基于开普勒优化算法(KOA)优化CNN-BiGRU-Attention混合网络的时间序列预测模型,MATLAB代码
算法·时间序列预测模型·开普勒优化算法