网站建站免费南昌seo计费管理
239. 滑动窗口最大值
- 原题链接:
- 完成情况:
- 解题思路:
- 参考代码:
- 错误经验吸取
原题链接:
239. 滑动窗口最大值
https://leetcode.cn/problems/sliding-window-maximum/description/
完成情况:
解题思路:
随时随地维护一个大小为k的堆
参考代码:
class Solution {public int[] maxSlidingWindow(int[] nums, int k) { //随时随地维护一个大小为k的堆if (nums == null || nums.length == 0 || k == 0) {return new int[0];}//存放结果元素的数组int [] res = new int[nums.length - k + 1];int num = 0;//自定义队列MyQueue myQueue = new MyQueue();//先将前K的元素放入队列for (int i = 0; i < k;i++){myQueue.add(nums[i]);}res[num++] = myQueue.peek();for (int i = k; i < nums.length; i++) {//滑动窗口移除最前面的元素,移除是判断该元素是否放入队列myQueue.poll(nums[i - k]);//滑动窗口加入最后面的元素myQueue.add(nums[i]);//记录对应的最大值res[num++] = myQueue.peek();}return res;}
}class MyQueue {Deque<Integer> deque = new LinkedList<>();//弹出元素时,比较当前要弹出的数值是否等于队列出口的数值,如果相等则弹出//同时判断队列当前是否为空void poll(int val) {if (!deque.isEmpty() && deque.peek() == val) {deque.poll();}}//添加元素时,如果要添加的元素大于入口处的元素,就将入口元素弹出//保证队列元素单调递减//比如此时队列元素3,1,2将要入队,比1大,所以1弹出,此时队列:3,2void add(int val) {while (!deque.isEmpty() && deque.getLast() < val) {deque.removeLast();}deque.add(val);}//队列队顶元素始终为最大值int peek() {return deque.peek();}
}