Leetcode——239. 滑动窗口最大值

题解一

思路

第一次做困难的题,确实把我既困住了又难住了,确实自己一点都想不出来。

这个思路,差不多就是,自己定义一个单调队列。

添加的时候,判断是否比队列最后的元素大,如果比它大,就把末尾的元素弹出,保证队列里从队头到队尾是单调递减的,这样的话,peek()方法调出的元素,就永远是滑动窗口里最大的元素;删除元素的时候,因为有些元素有可能在还没删除的时候就已经被删掉了,所以说要判断被删的元素是不是在单调队列里(这也是我后面暴力解的时候,没解决的问题),如果在队列里就把他删掉,由队列里第二大的元素变成队头。peek()方法调用的依旧是滑动窗口里最大的元素。

代码

java 复制代码
class Solution {
    public int[] maxSlidingWindow(int[] nums, int k) {

        if(k == 1){
            return nums;
        }

        int length = nums.length;
        MyQueue myQueue = new MyQueue();
        int[] maxNums = new int [length - k + 1];

        for(int i = 0; i < k; i++){
            myQueue.offer(nums[i]);
        }

        maxNums[0] = myQueue.peek();
        int index = 1;

        for(int i = k; i < length; i++){
            myQueue.offer(nums[i]);
            myQueue.poll(nums[i - k]);

            maxNums[index++] = myQueue.peek();
        }
        return maxNums;
    }
}
class MyQueue{
    Deque<Integer> queue = new ArrayDeque<>();
    
    public void offer(int val){
        while(!queue.isEmpty() && val > queue.getLast()){
            queue.removeLast();
        }
        queue.offer(val);
    }

    public void poll(int val){
        if(!queue.isEmpty() && val == queue.peek()){
            queue.poll();
        }
    }

    public int peek(){
        return queue.peek();
    }
}

总结

不愧是困难的题,确实想不出来。但是掌握单调队列这个解题思路,以及getLast()方法,还有removeLast()方法。

题解二

思路

暴力解思路就很简单了,每次有元素的替换的时候就遍历下数组里的元素,看看哪个最大

ps:但是这道题是困难,因此有几个用例会超时,所以并不算严格意义上的题解。

代码

java 复制代码
class Solution {
    public int[] maxSlidingWindow(int[] nums, int k) {

        int length = nums.length;

        if(k == 1){
            return nums;
        }

        if(k == length){
            int max = 0;
            for(int i : nums){
                if(i > max){
                    max = i;
                }
            }
            return new int[]{max};
        }

        int maxNums[] = new int [length - k + 1];
        int max = 0;
        int left = 0;
        int right = 0;
        int index = 0;

        while(right < length){
            if(right - left < k - 1){
                right++;
            }
            else if(right - left == k - 1){
                int max2 = nums[left];
                for(int i = left; i <= right; i++){
                    if(nums[i] > max2){
                        max2 = nums[i];
                    }
                }
                maxNums[index++] = max2;
                left++;
            }
        }
        return maxNums;
    }
}
相关推荐
abcnull4 小时前
用javaparser做精准测试
java·ast·静态代码分析·精准测试·javaparser
叶小鸡4 小时前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
AI人工智能+电脑小能手4 小时前
【大白话说Java面试题】【Java基础篇】第22题:HashMap 和 HashSet 有哪些区别
java·开发语言·哈希算法·散列表·hash
昵称小白4 小时前
复杂度分析方法
算法
juniperhan4 小时前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink
科研前沿4 小时前
2026 数字孪生前沿科技:全景迭代报告 —— 镜像视界生成式孪生(Generative DT)技术白皮书
大数据·人工智能·科技·算法·音视频·空间计算
ID_180079054734 小时前
Python 实现亚马逊商品详情 API 数据准确性校验(极简可用 + JSON 参考)
java·python·json
c++之路5 小时前
C++23概述
java·c++·c++23
专注API从业者6 小时前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库
摇滚侠6 小时前
DBeaver 导入数据库 导入 SQL 文件 MySQL 备份恢复
java·数据库·mysql