【单调栈】最大宽度坡

java 复制代码
public int maxWidthRamp(int[] nums) {
        /*  此方法思路正确,但超时
              int n = nums.length;
              Deque<Integer> stack;
              int max = 0;
              for (int i = 0; i < n; i++) {
                 stack = new LinkedList<>();
                 stack.push(nums[i]);
                 int j = i + 1;
                 while (j < n) {
                   stack.push(nums[j]);
                   if (nums[j] >= nums[i] && stack.size() > max) {
                      max = stack.size();
                   }
                   j++;
                }
              }
              return max == 0 ? 0 : max - 1;
         */

        /**
         * 单调栈, 栈中存储的是从nums[0]开始的递减序列的下标,这些递减序列就是栈底
         *          然后逆序遍历数组计算哪个坡度最宽即可。
         *
         * 这里有个问题就是:为什么栈中代表的数据就是栈底呢?
         *     我们最后要求的最大的宽度坡一定是以这个序列中的某一个i为坡底的,我们反证一下:
         *     假设存在某个元素位置k不存在于上面的递减序列中,且有最大宽度j-k,
         *     这也就说明k位置的元素一定是小于k前面所有的元素的,否则就会有更长的宽度,
         *     但是既然k小于前面所有的元素,那么k就一定会被加入到该递减序列中,
         *     与假设矛盾,所以不存在k,解一定存在递减序列中
         *
         *      以 [6, 1, 8, 2, 0, 5] 为例,可以带入试验。
         */
        int n = nums.length;
        int max = 0;
        Deque<Integer> stack = new LinkedList<>();
        for (int i = 0; i < n; i++) {
            if (stack.isEmpty() || nums[stack.peek()] > nums[i]) {
                stack.push(i);
            }
        }
        for (int i = n - 1; i >= 0; i--) {
            while (!stack.isEmpty() && nums[stack.peek()] <= nums[i]) {
                int pos = stack.poll();
                max = Math.max(max,i - pos);
            }
        }
        return max;
    }
相关推荐
不倒翁玩偶7 分钟前
IDEA导入新的SpringBoot项目没有启动按钮
java·spring boot·intellij-idea
静听山水16 分钟前
Redis核心数据结构-ZSet
数据结构·redis
小小小米粒22 分钟前
Maven Tools
java
铉铉这波能秀27 分钟前
LeetCode Hot100数据结构背景知识之字典(Dictionary)Python2026新版
数据结构·python·算法·leetcode·字典·dictionary
蜡笔小马36 分钟前
10.Boost.Geometry R-tree 空间索引详解
开发语言·c++·算法·r-tree
kali-Myon37 分钟前
2025春秋杯网络安全联赛冬季赛-day1
java·sql·安全·web安全·ai·php·web
我是咸鱼不闲呀40 分钟前
力扣Hot100系列20(Java)——[动态规划]总结(下)( 单词拆分,最大递增子序列,乘积最大子数组 ,分割等和子集,最长有效括号)
java·leetcode·动态规划
唐梓航-求职中1 小时前
编程-技术-算法-leetcode-288. 单词的唯一缩写
算法·leetcode·c#
仟濹1 小时前
【算法打卡day3 | 2026-02-08 周日 | 算法: BFS】3_卡码网99_计数孤岛_BFS | 4_卡码网100_最大岛屿的面积DFS
算法·深度优先·宽度优先
清水白石0081 小时前
深入解析 LRU 缓存:从 `@lru_cache` 到手动实现的完整指南
java·python·spring·缓存