Cod sursa(job #1131039)

Utilizator Andrei1998Andrei Constantinescu Andrei1998 Data 28 februarie 2014 17:25:10
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.75 kb
#include <fstream>
#include <deque>

using namespace std;

int sir[5000005];

int main()
{
    ifstream cin("deque.in");
    ofstream cout("deque.out");

    int n=0,i,k;

    long long int suma=0;
    cin>>n>>k;

    for(i=1;i<=n;i++)
        cin>>sir[i];

    deque<int> coada;
    for(i=1;i<=n;i++)
    {
        while(!coada.empty())
            if(sir[coada.back()]>=sir[i])
                coada.pop_back();
            else
                break;

        coada.push_back(i);
        while(!coada.empty())
            if(i-coada.front()>=k)
                coada.pop_front();
            else
                break;

        if(i>=k)
            suma+=sir[coada.front()];
    }

    cout<<suma<<'\n';

    return 0;
}