[POJ2823]Sliding Window 滑動窗口(單調隊列)

題意

剛學單調隊列的時候作過spa

如今從新作一次code

一個很經典的題目blog

 

如今有一堆數字共N個數字(N<=10^6),以及一個大小爲k的窗口。如今這個從左邊開始向右滑動,每次滑動一個單位,求出每次滑動後窗口中的最大值和最小值。隊列

思路

單調隊列io

一個遞增class

一個遞減im

代碼

//author: sysky
#include<cstdio>
#define N 1000006
#define INF 0X3FFFFFFF
using namespace std;
int n,k;
int mina[N],maxa[N];
int minb[N],maxb[N];
int maxl=0,maxr=1,ansmax[N];
int minl=0,minr=1,ansmin[N];
int main()
{
    int i;
    scanf("%d%d",&n,&k);
    maxa[0]=INF;
    mina[0]=-INF;
    for(int i=1,a;i<=n;i++)
    {
        scanf("%d",&a);
        while(maxb[maxl]<=i-k && maxl<maxr) ++maxl;
        while(minb[minl]<=i-k && minl<minr) ++minl;
        while(maxa[maxr-1]<=a && maxl<maxr) --maxr;
        while(mina[minr-1]>=a && minl<minr) --minr;
        maxa[maxr]=mina[minr]=a;
        maxb[maxr++]=minb[minr++]=i;
        ansmax[i]=maxa[maxl];
        ansmin[i]=mina[minl];
    }
    for(int i=k;i<=n;i++) printf("%d ",ansmin[i]);
    puts("");
    for(int i=k;i<=n;i++) printf("%d ",ansmax[i]);
    return 0;
}

END.img

相關文章
相關標籤/搜索