LeetCode Hot100 239.滑动窗口最大值

题目描述

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

返回 滑动窗口中的最大值

239. 滑动窗口最大值 - 力扣(LeetCode)

思路

维护一个单调栈,保证栈内的元素单调递减

那么每次插入就和栈顶作比较。

如果不满足某些性质,直接弹出栈顶,直到栈为空或满足该性质插入这个元素。

代码

java 复制代码
class Solution {
    public int[] maxSlidingWindow(int[] nums, int k) {
        int n=nums.length;
        int[] ans=new int[n-k+1];
        Deque<Integer> dq=new LinkedList<>();
        for(int i=0;i<n;i++){
            while(!dq.isEmpty()&&nums[i]>nums[dq.peekLast()]){
                dq.pollLast();
            }
            dq.addLast(i);
            while(dq.peekFirst()<i-k+1){
                dq.pollFirst();
            }
            if(i>=k-1){
                ans[i-k+1]=nums[dq.peekFirst()];
            }
        }
        return ans;
    }
}
相关推荐
一只叁木Meow12 分钟前
电商 SKU 选择器:用算法实现优雅的用户交互
前端·javascript·算法
代码中介商17 分钟前
红黑树完全指南:从五条性质到完整插入删除实现
数据结构·算法
JieE21219 分钟前
反转链表:从双指针到递归,吃透链表反转的核心逻辑
javascript·算法
玖釉-36 分钟前
旋转图像:从矩阵转置、镜像到坐标变换的系统理解
c++·windows·算法·图形渲染
fengenrong1 小时前
20260522
算法
一条大祥脚1 小时前
Codeforces Round 1099 (Div. 2) 构造|贪心|图论|还原数组
java·算法·图论
Sheldon Chao1 小时前
Lecture 7 基于策略梯度的算法
人工智能·算法·机器学习
始三角龙2 小时前
LeetCode hoot 100 -- 缺失的第一个正整数
算法·leetcode·职场和发展
飞Link2 小时前
深度解析孪生网络(Siamese Network):从原理、技巧到实战应用
算法·数据挖掘·回归
测试狗科研平台2 小时前
洞悉微观电荷流动,VASP计算电荷密度分布
算法·云计算·开源软件