Cod sursa(job #1861324)

Utilizator cyg_SerbanBFlorin Gheorghe cyg_SerbanB Data 28 ianuarie 2017 19:35:48
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.68 kb
#include <cstdio>
#include <queue>
using namespace std;
struct myint
{
    int x,y;
};
deque<myint>  q;
int v[5000010];
int main()
{
    freopen("deque.in","r",stdin);
    freopen("deque.out","w",stdout);
   long long int i,n,k,max;
    myint a;
    scanf("%d %d",&n,&k);
    for(i=1; i<=n; ++i)
        scanf("%d",&v[i]);
    max=0;
    for(i=1; i<=n; ++i)
    {
        while(!q.empty() && q.back().x>=v[i])
            q.pop_back();
        while(!q.empty() && i-q.front().y+1>k)
            q.pop_front();
        a.x=v[i];
        a.y=i;
        q.push_back(a);
        if(i>=k)
            max=max+q.front().x;
    }
    printf("%lld",max);
    return 0;
}