Leetcode 239 滑动窗口最大值

本文详细解析了LeetCode 239题——滑动窗口最大值的算法实现,通过使用双向队列来高效地解决窗口内最大值的问题,避免了传统方法中的重复计算,提高了算法效率。

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

Leetcode 239 滑动窗口最大值

给定一个数组 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
详解:这道题是一道hard的题目,实现起来确实没有那么容易,对于一串数字,如果知道了其中最大的数字,那么再加入一个新的数字之后,我们可以很容易地找到新串最大的数字,但是如果拿走一个数字以后我们就会开始难以找到新串的最大数字了,必须遍历整个数字串才能获得,对于此类问题,我们可以使用一个双向队列来解决。
双向队列仅仅保存索引值,双向队列的左侧表示这串数字中最大的那个数字的索引,如果准备加入的数字大于最右侧的数字,那么就把最右侧的索引值移除,这样这个双向队列代表的数字一定是从左到右递减的,接下来把新的数字加入到队列中,随后判断队列的长度是否超出了k,如果超过了k,则把最左侧的索引移除,接下来把队列最左侧的数字加入到返回结果中去。

class Solution {
    public int[] maxSlidingWindow(int[] nums, int k) {
        if(nums.length==0) return new int[0];
        LinkedList<Integer> dequeue = new LinkedList<>();
        int[] res = new int[nums.length-k+1];
        int index = 0;
        for(int i=0;i<nums.length;i++){
            while(!dequeue.isEmpty()&&nums[dequeue.peekLast()]<nums[i]){
                dequeue.removeLast();
            }
            dequeue.add(i);
            if(i-dequeue.peekFirst()==k) dequeue.removeFirst();
            if(i>=k-1) res[index++] =  nums[dequeue.peekFirst()];
        }
        return res;
    }
}
内容概要:本文档提供了关于“微型车间生产线的设计与生产数据采集试验研究”的毕业设计复现代码,涵盖从论文结构生成、机械结构设计、PLC控制系统设计、生产数据采集与分析系统、有限元分析、进度管理、文献管理和论文排版系统的完整实现。通过Python代码和API调用,详细展示了各个模块的功能实现和相互协作。例如,利用SolidWorks API设计机械结构,通过PLC控制系统模拟生产流程,使用数据分析工具进行生产数据的采集和异常检测,以及利用进度管理系统规划项目时间表。 适合人群:具有机械工程、自动化控制或计算机编程基础的学生或研究人员,尤其是从事智能制造领域相关工作的人员。 使用场景及目标:①帮助学生或研究人员快速搭建和理解微型车间生产线的设计与实现;②提供完整的代码框架,便于修改和扩展以适应不同的应用场景;③作为教学或科研项目的参考资料,用于学习和研究智能制造技术。 阅读建议:此资源不仅包含详细的代码实现,还涉及多个学科领域的知识,如机械设计、电气控制、数据分析等。因此,在学习过程中,建议读者结合实际操作,逐步理解每个模块的功能和原理,并尝试调整参数以观察不同设置下的系统表现。同时,可以参考提供的文献资料,深入研究相关理论和技术背景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值