高阶数据结构 --- 单调队列

大家好,这一期,我将带领大家学习一种算法竞赛中常用的数据结构 --- 单调队列

废话不多说,我们直接开始这一期的内容

一:什么是单调队列?

二:单调队列相关算法题

1. 题目一:【单调队列模板题】滑动窗口

cpp 复制代码
#include <iostream>
#include <deque>

using namespace std;

const int N = 1e6 + 10;

int n, k;
int a[N];

int main()
{
    cin >> n >> k;
    for(int i = 1; i <= n; i++) cin >> a[i];

    deque<int> q; // 存下标
    // 窗口内最小值 - 单调递增的队列 - 存下标
    for(int i = 1; i <= n; i++)
    {
        while(q.size() && a[q.back()] >= a[i]) q.pop_back();

        q.push_back(i);

        // 判断队列里面元素是否在合法窗口内
        if(q.back() - q.front() + 1 > k) q.pop_front();

        if(i >= k) cout << a[q.front()] << " ";
    }
    cout << endl;

    // 窗口内最大值 - 单调递减的队列 - 存下标
    q.clear();
    for(int i = 1; i <= n; i++)
    {
        while(q.size() && a[q.back()] <= a[i]) q.pop_back();

        q.push_back(i);

        if(q.back() - q.front() + 1 > k) q.pop_front();
        if(i >= k) cout << a[q.front()] << " ";
    }
    cout << endl;

    return 0;
}

2. 题目二:质量检测

cpp 复制代码
#include <iostream>
#include <deque>

using namespace std;

const int N = 1e6 + 10;

int n, m;
int a[N];

int main()
{
    cin >> n >> m;
    deque<int> q; // 单调递增的队列 - 存下标
    for(int i = 1; i <= n; i++)
    {
        cin >> a[i];
        while(q.size() && a[q.back()] >= a[i]) q.pop_back();

        q.push_back(i);

        if(q.back() - q.front() + 1 > m) q.pop_front();

        if(i >= m) cout << a[q.front()] << endl;
    }

    return 0;
}

好的,今天的分享就先到这里了,谢谢大家!!!

相关推荐
IronMurphy5 小时前
【算法三十九】994. 腐烂的橘子
算法
Ares-Wang6 小时前
算法》》旅行商问题 TSP、7座桥问题 哈密顿回路 深度优先 和 宽度优先
算法·深度优先·宽度优先
Liqiuyue6 小时前
Transformer:现代AI革命背后的核心模型
人工智能·算法·机器学习
WolfGang0073216 小时前
代码随想录算法训练营 Day34 | 动态规划 part07
算法·动态规划
And_Ii6 小时前
LCR 168. 丑数
c++
Kk.08027 小时前
Linux(十一)fork实例练习、文件操作示例及相关面试题目分享
linux·运维·算法
CoderMeijun7 小时前
C++ 时间处理与格式化输出:从 Linux 时间函数到 Timestamp 封装
c++·printf·stringstream·时间处理·clock_gettime
潇冉沐晴7 小时前
2026CCCC第三次模拟赛 部分题解
算法
WolfGang0073218 小时前
代码随想录算法训练营 Day32 | 动态规划 part05
算法·动态规划