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

相关推荐
梁辰兴1 小时前
数据结构:排序
数据结构·算法·排序算法·c·插入排序·排序·交换排序
野犬寒鸦2 小时前
力扣hot100:搜索二维矩阵 II(常见误区与高效解法详解)(240)
java·数据结构·算法·leetcode·面试
菜鸟得菜2 小时前
leecode kadane算法 解决数组中子数组的最大和,以及环形数组连续子数组的最大和问题
数据结构·算法·leetcode
楼田莉子2 小时前
C++算法专题学习——分治
数据结构·c++·学习·算法·leetcode·排序算法
一支鱼3 小时前
leetcode常用解题方案总结
前端·算法·leetcode
ulias2123 小时前
各种背包问题简述
数据结构·c++·算法·动态规划
m0_570466413 小时前
代码随想录算法训练营第二十八天 | 买卖股票的最佳实际、跳跃游戏、K次取反后最大化的数组和
java·开发语言·算法
吃着火锅x唱着歌3 小时前
LeetCode 1537.最大得分
算法·leetcode·职场和发展
数模加油站3 小时前
25高教社杯数模国赛【C题超高质量思路+可运行代码】第十弹
算法·数学建模·数模国赛·高教社杯全国大学生数学建模竞赛
ulias2123 小时前
动态规划入门:从记忆化搜索到动态规划
算法·动态规划