leetcode 热题 100_滑动窗口最大值

文章介绍了如何通过构造递减双端队列(Deque)实现滑动窗口问题中的最大值查找算法,避免了每次移除头部元素时重新遍历窗口的过程,提高了效率。Java代码示例展示了如何在LeetCode题目中应用这种方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题解一:

        双端队列:滑动窗口的本质是在窗口末尾添加一个元素,并移除头部的一个元素。对于添加的元素,直接和当前最大值比较即可,但对于移除的元素,如果移除的是原先的最大值,则需要重新遍历窗口寻找新的最大值,因此优化的重点在于避开遍历窗口这一步骤。通过构造一个递减的Deque双端队列,我们可以将当前最大值维护在队首,并且当最大值被移除时,新的最大值依然在队首。而添加的元素则可以从队尾插入,同时,可以将队尾小于添加元素的值全部移除,因为位于窗口末尾的元素一定比其他元素晚移除,比它小的值不可能成为窗口的最大值。以下附上动画演示(来源. - 力扣(LeetCode)

import java.util.Deque;
import java.util.LinkedList;

class Solution {
    public int[] maxSlidingWindow(int[] nums, int k) {
        int[] maxNums = new int[nums.length - k + 1];
        Deque<Integer> deque = new LinkedList<>();

        for (int left = 1 - k, right = 0; right < nums.length; left++, right++) {
            if (left > 0 && deque.peekFirst() == nums[left - 1])
                deque.removeFirst();
            while (!deque.isEmpty() && deque.peekLast() < nums[right]) {
                deque.removeLast();
            }
            deque.addLast(nums[right]);
            if (left >= 0) maxNums[left] = deque.peekFirst();
        }

        return maxNums;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值