数据结构-单调队列

数据结构-单调队列

滑动窗口

时间复杂度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)

相关推荐
椰子今天很可爱13 分钟前
仿照muduo库实现一个高并发服务器
linux·服务器·c++
alphaTao1 小时前
LeetCode 每日一题 2025/12/15-2025/12/21
算法·leetcode
写写闲篇儿4 小时前
下一个更大元素(一)
数据结构·算法
MobotStone5 小时前
从金鱼记忆到过目不忘:Transformer 如何让AI真正理解一句话?
算法
lizz316 小时前
C++模板编程:从入门到精通
java·开发语言·c++
炽烈小老头6 小时前
【每天学习一点算法 2025/12/19】二叉树的层序遍历
数据结构·学习·算法
Queenie_Charlie7 小时前
HASH表
数据结构·c++·哈希算法
Xの哲學7 小时前
Linux grep命令:文本搜索的艺术与科学
linux·服务器·算法·架构·边缘计算
soft20015257 小时前
MySQL Buffer Pool深度解析:LRU算法的完美与缺陷
数据库·mysql·算法
superman超哥7 小时前
仓颉语言中锁的实现机制深度剖析与并发实践
c语言·开发语言·c++·python·仓颉