Cod sursa(job #2044257)

Utilizator BotezatuGabrielBotezatu Gabriel Eugen BotezatuGabriel Data 21 octombrie 2017 09:04:06
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.57 kb
#include <iostream>
#include <deque>
#include <queue>
#include <fstream>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
int v[5000001];
int main()
{
    long long i,s=0,n,k;
    fin>>n>>k;
    for(i=1; i<=n; ++i)
    {
        fin>>v[i];
    }
    deque <int> d;
    for(i=1; i<=n; ++i)
    {
        while(!d.empty() && v[d.back()]>=v[i])
            d.pop_back();
        d.push_back(i);
        if(i-k==d.front())
            d.pop_front();
        if(i>=k)
            s+=v[d.front()];
    }
    fout<<s;


    return 0;
}