数据结构-单调队列

数据结构-单调队列

滑动窗口

时间复杂度O(n)

1.滑动窗口中的最大值

C++ 复制代码
deque<int> d;//数组nums[1-n],窗口大小为k
for(int i=1;i<=n;i++)
{
    while(!d.empty()&&d.front()+k<=i) d.pop_front();
 	while(!d.empty()&&nums[d.back()]<=nums[i]) d.pop_back();   
    d.push_back(i);
    if(i>=k) printf("%d",d.front());
}

2.滑动窗口中的最小值

C++ 复制代码
deque<int> d;//数组nums[1-n],窗口大小为k
for(int i=1;i<=n;i++)
{
    while(!d.empty()&&d.front()+k<=i) d.pop_front();
 	while(!d.empty()&&nums[d.back()]>=nums[i]) d.pop_back();   
    d.push_back(i);
    if(i>=k) printf("%d",d.front());
}

P1886 滑动窗口 /【模板】单调队列 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

相关推荐
To_OC12 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户9385156350717 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC18 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥19 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者20 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者20 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月1 天前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星1 天前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星1 天前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试