滑动窗口的最大值
给你一个整数数组 nums
,有一个大小为 k
的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k
个数字。滑动窗口每次只向右移动一位。
返回 滑动窗口中的最大值 。
示例 1:
1 2 3 4 5 6 7 8 9 10 11
| 输入:nums = [1,3,-1,-3,5,3,6,7], k = 3 输出:[3,3,5,5,6,7] 解释: 滑动窗口的位置 最大值 --------------- ----- [1 3 -1] -3 5 3 6 7 3 1 [3 -1 -3] 5 3 6 7 3 1 3 [-1 -3 5] 3 6 7 5 1 3 -1 [-3 5 3] 6 7 5 1 3 -1 -3 [5 3 6] 7 6 1 3 -1 -3 5 [3 6 7] 7
|
示例 2:
1 2
| 输入:nums = [1], k = 1 输出:[1]
|
提示:
1 <= nums.length <= 105
-104 <= nums[i] <= 104
1 <= k <= nums.length
单调队列的模板题
1 2 3 4
| __________________
__________________ 队头 队尾
|
维护一个队列,使得从左到右的元素非递增,那么队头的元素就是最大值
- 每次从队尾插入新元素,为了保证非递增,把所有小于新元素的旧元素移除
- 插入新元素
- 如果队列长度超过k,将队头元素出列
- 当长度为k的滑动窗口形成后,将最大值加入答案数组
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| class Solution { public int[] maxSlidingWindow(int[] nums, int k) { int n = nums.length; int[] res = new int[n-k+1]; int a = 0; int[] q = new int[n]; int h = 0,t = 0; for(int i = 0;i<n;i++){ while(h<t&&nums[q[t-1]]<nums[i]){ t--; } q[t++] = i; if(i-q[h]>=k){ h++; } if(i+1>=k){ res[a++] = nums[q[h]]; } } return res; } }
|