当前位置: 首页 > article >正文

【LeetCode刷题-滑动窗口】-- 239.滑动窗口最大值

239.滑动窗口最大值

image-20231118191937241

分析:

image-20231118192024119

方法:优先队列

对于最大值,可以使用优先队列(堆),其中的大根堆可以帮助实时维护一系列元素中的最大值

在本题中,初始时,将数组nums的前k个元素放入优先队列中,每当我们向右移动窗口时,我们就可以把一个新的元素放入优先队列中,此时堆顶的元素就是堆中所有元素的最大值,然而这个最大值可能并不在滑动窗口中,在这种情况下,这个值在数组nums中的位置出现在滑动窗口左边界的左侧,因此我们后续继续向右移动滑动窗口,这个值就永远不可能出现在滑动窗口中了,就可以将其永久地从优先队列中移除

不断移除堆顶的元素,直到其确实出现在滑动窗口中,此时堆顶元素就是滑动窗口中的最大值,为了方便判断堆顶元素与滑动窗口的关系,可以在优先队列中存储二元组(num,index),表示元素num在数组的下标为index

class Solution {
    public int[] maxSlidingWindow(int[] nums, int k) {
        int n = nums.length;
        //1.优先队列存放的是二元组(num,index):大顶堆(元素大小不同按元素大小排列,元素大小相同按下标进行排列)
        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];
            }
        });

        //2.优先队列初始化:k个元素的堆
        for(int i = 0;i<k;i++){
            pq.offer(new int[]{nums[i],i});
        }
        //3.处理堆逻辑
        int[] res = new int[n - k + 1];  //初始化结果数组长度:一共有n - k + 1个窗口
        res[0] = pq.peek()[0];   //初始化res[0]:拿出目前堆顶的元素
        for(int i = k;i<n;i++){   //向右移动滑动窗口
            pq.offer(new int[]{nums[i],i});   //加入大顶堆种
            while(pq.peek()[1] <= i - k){   //将下标不在滑动窗口中的元素都移除
                pq.poll();         //维护:堆的大小就是滑动窗口的大小
            }
            res[i - k + 1] = pq.peek()[0];  //此时堆顶元素就是滑动窗口的最大值
        }
        return res;
    }
}

http://www.kler.cn/a/133217.html

相关文章:

  • 【【萌新的SOC学习之 VDMA 彩条显示实验之一】】
  • 【RocketMq系列-01】RocketMq安装和基本概念
  • TG Pro v2.87(mac温度风扇速度控制工具)
  • 拒绝服务攻击工具的编写
  • 永久关机windows系统自动更新
  • linux时间调整
  • 使用记录-MongoDB
  • openai/chatgpt的api接口,各个模型的最大输入token一览表
  • 适用于全部安卓手机的 5 大免费 Android 数据恢复
  • 037、目标检测-算法速览
  • 「git 系列」git 如何存储代码的?
  • 6.9平衡二叉树(LC110-E)
  • WPF实现将鼠标悬浮在按钮上时弹出菜单
  • MyBatis逆向工程
  • 小型企业网络搭建方案
  • FPGA模块——IIC协议(读写PCF8591)
  • linux进程间通信之共享内存(mmap,shm_open)
  • asp.net学生成绩评估系统VS开发sqlserver数据库web结构c#编程计算机网页项目
  • AI语音克隆
  • Flink1.17 DataStream API