双端队列(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),每个索引最多入队出队一次。
相关推荐
Stardep6 小时前
算法入门19——二分查找算法——X的平方根
算法·leetcode·二分查找算法
We་ct6 小时前
LeetCode 135. 分发糖果:双向约束下的最小糖果分配方案
前端·算法·leetcode·typescript
宇钶宇夕6 小时前
CoDeSys入门实战一起学习(十三):函数(FUN)深度解析:自定义、属性与实操案例
运维·算法·自动化·软件工程
l1t7 小时前
对clickhouse给出的二分法求解Advent of Code 2025第10题 电子工厂 第二部分的算法理解
数据库·算法·clickhouse
Tisfy7 小时前
LeetCode 3315.构造最小位运算数组 II:位运算
算法·leetcode·题解·位运算
YuTaoShao7 小时前
【LeetCode 每日一题】1292. 元素和小于等于阈值的正方形的最大边长
算法·leetcode·职场和发展
Remember_9937 小时前
【数据结构】深入理解Map和Set:从搜索树到哈希表的完整解析
java·开发语言·数据结构·算法·leetcode·哈希算法·散列表
浅念-7 小时前
C++第一课
开发语言·c++·经验分享·笔记·学习·算法
charlie1145141917 小时前
现代嵌入式C++教程:对象池(Object Pool)模式
开发语言·c++·学习·算法·嵌入式·现代c++·工程实践
燃于AC之乐7 小时前
我的算法修炼之路--8——预处理、滑窗优化、前缀和哈希同余,线性dp,图+并查集与逆向图
算法·哈希算法·图论·滑动窗口·哈希表·线性dp