算法通关村第十六关——滑动窗口与堆结合

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

复制代码
输入: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
复制代码
public int[] maxSlidingWindow(int[] nums, int k) {
    int n = nums.length;
    PriorityQueue<int[]> pq = new PriorityQueue<int[]>(new Comparator<int[]>() {
        public int compare(int[] pair1, int[] pair2) {
            return pair1[0] != pair2[0] ? pair2[0] - pair1[0] : pair2[1] - pair1[1];
        }
    });
    for (int i = 0; i < k; i++) {
        pq.offer(new int[]{nums[i], i});
    }
    int[] ans = new int[n - k + 1];
    ans[0] = pq.peek()[0];
    for (int i = k; i < n; i++) {
        pq.offer(new int[]{nums[i], i});
        while (pq.peek()[1] <= i - k) {
            pq.poll();
        }
        ans[i - k + 1] = pq.peek()[0];
    }
    return ans;
}

优先队列中每个值存储的是一个包含元素值和对应索引的数组 [元素值, 索引]。在这段代码中,优先队列 pq 存储的是这样的数组。

pq.peek()[1] <= i - k

  1. 表示队首元素的索引值是否小于等于当前滑动窗口的起始索引。

  2. 如果队首元素的索引值小于等于当前滑动窗口的起始索引,则说明该元素已经不在当前滑动窗口的范围内,需要将其从优先队列中移除。

相关推荐
DN20203 分钟前
当AI开始评估客户的“成交指数”
数据结构·人工智能·python·microsoft·链表
苏荷水25 分钟前
万字总结LeetCode100(持续更新...)
java·算法·leetcode·职场和发展
gihigo199837 分钟前
MATLAB运动估计基本算法详解
开发语言·算法·matlab
hetao173383738 分钟前
2026-02-09~02-12 hetao1733837 的刷题记录
c++·算法
ADDDDDD_Trouvaille39 分钟前
2026.2.12——OJ72-74题
c++·算法
励ℳ1 小时前
机器学习-LASSO算法指南
人工智能·算法·机器学习
Vic101011 小时前
算法D1-20260212:双指针专题
java·数据结构·算法
仟濹1 小时前
【算法打卡day7(2026-02-12 周四)算法:BFS and BFS】10__卡码网110_字符串迁移, 11_卡码网105_有向图的完全连通
算法·深度优先·dfs·bfs·宽度优先
935961 小时前
机考24 翻译18 单词11
c语言·数据结构·算法