Cod sursa(job #2582059)

Utilizator lucamLuca Mazilescu lucam Data 16 martie 2020 12:45:09
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.59 kb
#include <fstream>
#include <deque>
using namespace std;

const int NM = 5e6;
int v[NM];

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

int main()
{
    int n, k;
    fin >> n >> k;
    long long s = 0;
    deque<int> deq;
    for (int i = 0; i < n; ++i) {
        fin >> v[i];
        while (!deq.empty() && v[deq.front()] >= v[i])
            deq.pop_front();
        deq.push_front(i);
        while (!deq.empty() && i - deq.back() >= k)
            deq.pop_back();
        if (i >= k - 1)
            s += v[deq.back()];
    }
    fout << s << '\n';
    return 0;
}