Cod sursa(job #1478148)

Utilizator Vlad_lsc2008Lungu Vlad Vlad_lsc2008 Data 28 august 2015 00:37:49
Problema Deque Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.76 kb
#include <deque>
#include <cstdio>
using namespace std;

deque < pair <int,int> > c;
long long rez;
int n,k;

int main()
{
    freopen("deque.in","r",stdin);
    freopen("deque.out","w",stdout);
    int i,x;
    scanf("%d%d%d",&n,&k,&x);
    c.push_front( make_pair(x,1));
    for(i=2;i<=k;i++)
    {
        scanf("%d",&x);
        while(!c.empty() && c.back().first>=x) c.pop_back();
        c.push_back(make_pair(x,i));
    }
    for(i=k+1;i<=n;i++)
    {
        scanf("%d",&x);
        rez+=c.front().first;
        if(c.front().second<=i-k) c.pop_front();
        while(!c.empty() && c.back().first>=x) c.pop_back();
        c.push_back(make_pair(x,i));
    }
    printf("%lld",rez);
    fclose(stdin);
    fclose(stdout);
    return 0;
}