首页 > 其他 > 详细

题解【洛谷P1886】滑动窗口 /【模板】单调队列

时间:2020-01-31 22:00:41      阅读:66      评论:0      收藏:0      [点我收藏+]

题面

单调队列模板题。

单调队列可以从队首和队尾出队。

队列中的元素大小具有一定的顺序。

具体可参考这一篇题解

#include <bits/stdc++.h>
#define itn int
#define gI gi

using namespace std;

inline int gi()
{
    int f = 1, x = 0; char c = getchar();
    while (c < '0' || c > '9') {if (c == '-') f = -1; c = getchar();}
    while (c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
    return f * x;
}

const int maxn = 1000003;

int n, k, a[maxn], q[maxn], p[maxn];

inline void getmin()
{
    int head = 1, tail = 0;
    for (int i = 1; i <= n; i+=1)
    {
        while (head <= tail && q[tail] >= a[i]) --tail;
        q[++tail] = a[i];
        p[tail] = i;
        while (p[head] <= i - k) ++head;
        if (i >= k) printf("%d ", q[head]);
    }
    puts("");
}

inline void getmax()
{
    int head = 1, tail = 0;
    for (int i = 1; i <= n; i+=1)
    {
        while (head <= tail && q[tail] <= a[i]) --tail;
        q[++tail] = a[i];
        p[tail] = i;
        while (p[head] <= i - k) ++head;
        if (i >= k) printf("%d ", q[head]); 
    }
    puts("");
}

int main()
{
    //freopen(".in", "r", stdin);
    //freopen(".out", "w", stdout);
    n = gi(), k = gi();
    for (int i = 1; i <= n; i+=1) a[i] = gi();
    getmin();
    getmax();
    return 0;
}

题解【洛谷P1886】滑动窗口 /【模板】单调队列

原文:https://www.cnblogs.com/xsl19/p/12246845.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!