1. Job Roadmap
  2. Home
  3. Problem Set
  4. codenotelist
  5. Forum
  6. course
  7. Shore Share Sessions
  8. Record
  1. Login
  2. Sign Up
  3. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
    ZhContent TextSol AI分析

思路(单调队列)

核心数据结构:维护一个下标的双端队列 dqdqdq,使得队列中对应的值严格单调递减。这样队首始终是当前窗口的最大值下标。

对每个下标 iii 执行:

  1. 删除过期:如果 dqdqdq 的队首下标小于当前窗口的左边界(即 dq.front()≤i−kdq.front() \le i-kdq.front()≤i−k),就从队首弹出。
  2. 维护单调性:当 nums[dq.back()]≤nums[i]nums[dq.back()] \le nums[i]nums[dq.back()]≤nums[i] 时,从队尾弹出,直到队列对应值重新递减。
  3. 加入新元素:把 iii 加到队尾。

P3742.第3题-滑动窗口最大值

    1000ms Tried: 144 Accepted: 57 Difficulty: 5 所属公司 : 新凯来
    算法与标签>队列

题目内容

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

返回 滑动窗口中的最大值。

输入描述

第一行输入111个整数,分别为{nnn} 的个数,1<=nums.length<=1051 <= nums.length <=10^51<=nums.length<=105

第二行输入数列{nnn},用空格隔开,−104<=nums1<=104-10^4 <= nums1<=10^4−104<=nums1<=104

第三行输入111个整数,滑窗长度,1<=k<=nums.length1<=k<=nums.length1<=k<=nums.length

输出描述

结果输出一行,数组每个滑窗的最大值

样例1

输入

8
1 3 -1 -3 5 3 6 7
3

输出

3 3 5 5 6 7

登录后即可使用 AI 分析。

模式
倒计时时长
:

最长 10 小时 59 分;应用后按此时长重新开始。

提示:点击提交记录在左侧题面区域查看详情
题库
AI分析设置
留空使用官方API Key,每天有次数限制(自定义API Key仅限会员和管理员使用,不限次数)
会员和管理员可切换模型;切到 Kimi/智谱/通义/豆包时需填写对应供应商 API Key
升级会员,可将运行与提交冷却时间缩短至 1 秒起

Status

  • Judging Queue
  • Service Status

Development

  • Open Source

Support

  • Help
  • Contact Us

About

  • About
  • Privacy
  • Terms of Service
  • Copyright Complaint
  1. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
  2. Legacy mode
  3. Theme
    1. Light
    2. Dark
  1. 京ICP备2025123107号-1
  2. Worker 1, 36ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

请使用微信扫描下方二维码完成注册

Forgot password or username?