Cod sursa(job #1262937)

Utilizator ZimmyZimmermann Erich Zimmy Data 13 noiembrie 2014 18:23:10
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.69 kb
#include <fstream>
#include <deque>
#define valoare first
#define indice second
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
long long sol;
int n,i,x,k;
deque <pair<int,int> > q;
int main()
{
    fin>>n>>k;
    for(i=1;i<k;i++)
    {
        fin>>x;
        while(q.size()&&x<=q.back().valoare)
            q.pop_back();
        q.push_back(make_pair(x,i));
    }
    for(i=k;i<=n;i++)
    {
        fin>>x;
        while(q.size()&&x<=q.back().valoare)
            q.pop_back();
        q.push_back(make_pair(x,i));
        if(q.front().indice==i-k)
            q.pop_front();
        sol+=q.front().valoare;
    }
    fout<<sol;
    return 0;
}