单调队列相关

  • 单 调 队 列 的 内 容 单调队列的内容

顾名思义, 始终 单调递增单调递减双端队列 即为单调队列 .

接下来以 滑动窗口 为例说一下基础的单调队列操作.

设当前枚举到了 A i A_i Ai, 且维护的是从队首到队尾单调递增的队列, (队首比队尾入队时间早)

  1. 若队列为空, 直接将 A i A_i Ai 入队.
  2. 若队列不为空, 设队尾为 b k bk bk,
    1. A b k &gt; A i A_{bk}&gt;A_i Abk>Ai, 则不断弹出队尾, 直到 A b k &lt; = A i A_{bk}&lt;=A_i Abk<=Ai.
    2. A b k &lt; = A i A_{bk}&lt;=A_i Abk<=Ai, 直接从队尾入队 .

由于 队首 可能不在题目中的 “滑动窗口” 中, 所以每次输出答案时要弹掉不合法的元素, 最后最小值即为 队首 .

时间复杂度 O ( N ) O(N) O(N) .

最大值同理, 这里不再赘述.

  • 单 调 队 列 的 应 用 单调队列的应用

单调队列同样可以作为 斜率优化 实现的工具, 没学过斜率优化的同学可以点击 这里.

例题 .

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值