hot100 239.滑动窗口最大值

思路:利用单调队列维护滑动窗口。

1.右边入(元素进入队尾,同时维护队列的单调性)。

2.左边出(元素离开队首)。

3.记录/维护答案(根据队首)。

为什么代码中的队首离开窗口写的是if而不是while?

答:

这是因为窗口在一步一步地向右滑动(像只蜗牛),所以元素也是一个一个地离开窗口,不会出现同一轮循环中有多个元素离开窗口的情况。

附代码:

java 复制代码
class Solution {
    public int[] maxSlidingWindow(int[] nums, int k) {
        int n = nums.length;
        int[] res = new int[n - k + 1]; //窗口个数
        LinkedList<Integer> queue = new LinkedList<>();
        for(int i = 0;i < n;i++){
            //1.右边入
            while(!queue.isEmpty() && nums[queue.getLast()] < nums[i]){
                queue.removeLast(); //移除所有比当前元素小的元素,确保队列中的元素是单调递减的
            }
            queue.addLast(i); //注意保存的是下标,这样下面可以判断队首是否离开窗口

            //2.左边出(移除过期元素)
            int left = i - k + 1; //窗口左端点
            if(queue.getFirst() < left){ //队首元素已不在窗口中,移除过期的队首元素
                queue.removeFirst();
            }
            //3.在窗口的左端点处记录答案
            if(left >= 0){
                //由于队首到队尾单调递减,所以窗口的最大值就在队首
                res[left] = nums[queue.getFirst()];
            }
        }
        return res;
    }
}
相关推荐
执着2591 分钟前
力扣hot100 - 199、二叉树的右视图
数据结构·算法·leetcode
I_LPL4 分钟前
day21 代码随想录算法训练营 二叉树专题8
算法·二叉树·递归
可编程芯片开发11 分钟前
基于PSO粒子群优化PI控制器的无刷直流电机最优控制系统simulink建模与仿真
人工智能·算法·simulink·pso·pi控制器·pso-pi
cpp_250112 分钟前
P8448 [LSOT-1] 暴龙的土豆
数据结构·c++·算法·题解·洛谷
YGGP12 分钟前
【Golang】LeetCode 49. 字母异位词分组
leetcode
lcj251112 分钟前
深入理解指针(4):qsort 函数 & 通过冒泡排序实现
c语言·数据结构·算法
fie888914 分钟前
基于MATLAB的转子动力学建模与仿真实现(含碰摩、不平衡激励)
开发语言·算法·matlab
唐梓航-求职中21 分钟前
编程大师-技术-算法-leetcode-1472. 设计浏览器历史记录
算法·leetcode
_OP_CHEN24 分钟前
【算法基础篇】(五十八)线性代数之高斯消元法从原理到实战:手撕模板 + 洛谷真题全解
线性代数·算法·蓝桥杯·c/c++·线性方程组·acm/icpc·高斯消元法
YGGP30 分钟前
【Golang】LeetCode 1. 两数之和
leetcode