LeetCode Hot100 239.滑动窗口最大值

题目

给你一个整数数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。

返回 滑动窗口中的最大值 

思路

代码

class Solution {
    public int[] maxSlidingWindow(int[] nums, int k) {
        int n = nums.length;
        int[] ans = new int[n - k + 1]; // 记录结果
        Deque<Integer> q = new ArrayDeque<>(); // 双端队列   队首到队尾是递减的
        for (int i = 0; i < n; i++) {
            // 1.入
            while (!q.isEmpty() && nums[q.getLast()] <= nums[i]) {
                q.removeLast(); // 维护q的单调性
            }
            q.addLast(i); // 入队
            // 2.出( 弹出队首不在窗口内的元素 )
            if (i - q.getFirst() >= k) {
                q.removeFirst();
            }
            // 3.记录答案 
            if (i >= k - 1) {
                // 由于队首到队尾单调递减,所以窗口最大值就是队首
                ans[i - k + 1] = nums[q.getFirst()];
            }
        }
        return ans;
    }
}

滑动窗口问题三部曲

1、入

2、出

3、记录答案

相关推荐

  1. 【Leetcode】239. 滑动窗口

    2023-12-19 14:00:04       63 阅读
  2. 【LeetCode】239. 滑动窗口

    2023-12-19 14:00:04       55 阅读
  3. Leetcode 239 滑动窗口

    2023-12-19 14:00:04       55 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-19 14:00:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-19 14:00:04       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-19 14:00:04       87 阅读
  4. Python语言-面向对象

    2023-12-19 14:00:04       96 阅读

热门阅读

  1. android的bundle的常用函数(ChatGPT)

    2023-12-19 14:00:04       57 阅读
  2. PCL 已知同名点对计算旋转矩阵并对点云进行旋转

    2023-12-19 14:00:04       65 阅读
  3. WordPress WP_Query参数使用说明

    2023-12-19 14:00:04       47 阅读
  4. 【selenium】自动化使用 chrome 的 user-data-dir

    2023-12-19 14:00:04       67 阅读
  5. 2312llvm,01基本介绍

    2023-12-19 14:00:04       55 阅读
  6. react项目:Table表格数据转换为图片下载保存

    2023-12-19 14:00:04       64 阅读
  7. 第1节 位运算、算法是什么、简单排序

    2023-12-19 14:00:04       59 阅读