Cod sursa(job #2635854)

Utilizator cyg_dawidDavid Ghiberdic cyg_dawid Data 15 iulie 2020 18:19:11
Problema Deque Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.66 kb

#include <fstream>
#include <deque>

using namespace std;

deque <int> deck;

const int NMAX = 5000005;
int v[NMAX], k, n;

ifstream fin("deque.in");
ofstream fout("deque.out");

int main()
{
    int i;
    long long s=0;
    fin >> n >> k;
    for(i = 1; i <= n; i++){
        fin >> v[i];
    }
    deck.push_back(10000050);
    for(i = 1; i <= n; i++){
        while(v[i] <= v[ deck[deck.back()] ] && deck.size() > 0)
            deck.pop_back();
        deck.push_back(i);
        if(deck.front() == i - k)
            deck.pop_front();
        if(i >= k)
            s += v[ deck.front() ];
    }
    fout << s;
    return 0;
}