Cod sursa(job #1675106)

Utilizator darisavuSavu Daria darisavu Data 5 aprilie 2016 09:06:43
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.55 kb
#include <fstream>
#include <deque>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
deque<int>d;
long long a[5000001],k,i,s=0,n,l=0;
int main()
{
    f>>n>>k;
    for(i=1;i<=n;i++) f>>a[i];
    d.push_back(1);
    for(i=2;i<=n;i++)
    {
        while(!d.empty()&&a[d.back()]>a[i])
        {
            if(d.size()==0)break;
               else d.pop_back();
        }
        d.push_back(i);
        if(d.back()-d.front()>=k) d.pop_front();
       if(i>=k) s=s+a[d.front()];

    }
    g<<s;
    return 0;
}