Cod sursa(job #2164641)

Utilizator andreiutu111Noroc Andrei Mihail andreiutu111 Data 13 martie 2018 08:56:26
Problema Deque Scor 25
Compilator cpp Status done
Runda Arhiva educationala Marime 0.44 kb
#include<bits/stdc++.h>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
int N,K,v[5000001],s,Front,Back,Deque[5000001];
int main()
{
    f>>N>>K;
    for(int i=1;i<=N;++i)f>>v[i];
    Front=1,Back=0;
    for(int i=1;i<=N;++i){
        while(Front<=Back&&v[i]<=v[Deque[Back]])--Back;
        Deque[++Back]=i;
        if(i-K==Deque[Front])++Front;
        if(K<=i)s+=v[Deque[Front]];
    }
    g<<s;
    return 0;
}