双端队列(Deque)

双端队列(Deque)要点速记:

  • 定义:两端都能插入/删除的队列。常用实现:ArrayDeque。
  • 常用操作(以 Deque<Integer> q = new ArrayDeque<>();):
  • 头部:q.addFirst(x) / q.removeFirst() / q.peekFirst()
  • 尾部:q.addLast(x) / q.removeLast() / q.peekLast()

ArrayDeque,操作有:addLast/removeLast(尾部),addFirst/removeFirst(头部),peekFirst/peekLast 查看头尾元素但不移除。

  • 用索引存储而非值:便于判断过期(是否滑出窗口)。
  • 滑动窗口最大值的单调队列套路:
  1. 先弹掉队头过期索引(peekFirst() <= i - k)

  2. 再弹掉队尾"劣势"索引(对应值 ≤ 当前值),保证值单调递减

  3. 把当前索引加到队尾

  4. 窗口形成后,队头即当前窗口最大值

  • 单调性的意义:队头始终是最大值;队尾只保留可能成为未来最大值的候选,时间复杂度 O(n),每个索引最多入队出队一次。
相关推荐
通信小呆呆6 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
benben0446 小时前
强化学习之DQN算法族(基于gymnasium开发)
算法
何以解忧,唯有..7 小时前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
想吃火锅10058 小时前
【leetcode】88.合并两个有序数组js
算法
生成论实验室8 小时前
机器人:一个自主运动的系统
人工智能·算法·语言模型·机器人·自动驾驶·agi·安全架构
Qres8219 小时前
算法复键——树状数组
数据结构·算法
H178535090969 小时前
SolidWorks第四部分_直接实体建模特征9_替换面原理
线性代数·算法·机器学习·3d建模·solidworks
不会就选b9 小时前
算法日常・每日刷题--<二分查找>3
算法
绿算技术9 小时前
Mooncake 与绿算ForinnBase GroundPool如何联手打破推理僵局?
科技·算法·架构