Cod sursa(job #1425732)

Utilizator CodrutLemeniCodrut Lemeni CodrutLemeni Data 27 aprilie 2015 22:23:38
Problema Deque Scor 60
Compilator c Status done
Runda Arhiva educationala Marime 0.67 kb
#include <stdio.h>
#include <stdlib.h>

long long v[5000010],deque[5000010];
long long i;
long long sum;
long long front,back,n,k;

int main()
{
    freopen("deque.in","r",stdin);
    freopen("deque.out","w",stdout);

    scanf("%lld %lld",&n,&k);


    for(i=1;i<=n;i++){
        scanf("%lld",&v[i]);
    }
    front=1;
    back=0;

    for(i=1;i<=n;i++){
        while(front<=back && v[i]<v[deque[back]]){
            back--;
        }
        back++;
        deque[back]=i;
        if(deque[front]==i-k){
            front++;
        }
        if(i>=k){
            sum+=v[deque[front]];
        }
    }
    printf("%lld",sum);
    return 0;
}