Cod sursa(job #1425736)

Utilizator CodrutLemeniCodrut Lemeni CodrutLemeni Data 27 aprilie 2015 22:26:36
Problema Deque Scor 100
Compilator c Status done
Runda Arhiva educationala Marime 0.65 kb
#include <stdio.h>
#include <stdlib.h>

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

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

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


    for(i=1;i<=n;i++){
        scanf("%d",&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;
}