算法修炼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).符合单调递减的情况时,全部入栈。

相关推荐
多喝开水少熬夜5 分钟前
Trie树相关算法题java实现
java·开发语言·算法
WBluuue20 分钟前
数据结构与算法:树上倍增与LCA
数据结构·c++·算法
bruk_spp37 分钟前
牛客网华为在线编程题
算法
黑屋里的马2 小时前
java的设计模式之桥接模式(Bridge)
java·算法·桥接模式
sin_hielo3 小时前
leetcode 1611
算法·leetcode
李小白杂货铺3 小时前
识别和破除信息茧房
算法·信息茧房·识别信息茧房·破除信息茧房·算法推荐型茧房·观点过滤型茧房·茧房
来荔枝一大筐4 小时前
C++ LeetCode 力扣刷题 541. 反转字符串 II
c++·算法·leetcode
暴风鱼划水4 小时前
算法题(Python)数组篇 | 6.区间和
python·算法·数组·区间和
zl_vslam4 小时前
SLAM中的非线性优-3D图优化之轴角在Opencv-PNP中的应用(一)
前端·人工智能·算法·计算机视觉·slam se2 非线性优化
是苏浙5 小时前
零基础入门C语言之C语言实现数据结构之顺序表应用
c语言·数据结构·算法