Cod sursa(job #2478857)

Utilizator darisavuSavu Daria darisavu Data 22 octombrie 2019 20:17:15
Problema Deque Scor 60
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.52 kb
#include <fstream>
#include <deque>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");
long long n,k,s,i,a[5000005];
deque<long long> d;
int main()
{
    f>>n>>k;
    for(i=1; i<=n; i++) f>>a[i];
    for(i=1; i<=n; i++)
    {
        while(!d.empty()&&a[i]<=a[d.back()]) d.pop_back();
        d.push_back(i);
        if(i>=k)
        {
            while(!d.empty()&&i-d.front()>=k)
                d.pop_front();

            s+=a[d.front()];
        }
    }
    g<<s;
    return 0;
}