Cod sursa(job #1786524)

Utilizator nedelcu11Nedelcu Mihai Vlad nedelcu11 Data 23 octombrie 2016 10:55:24
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.49 kb
#include <fstream>
#include <deque>
using namespace std;
ifstream in("deque.in");
ofstream out("deque.out");
int n, k, v[5000001];
int main()
{   in >> n >> k;
    for(int i = 1; i <= n; ++i) in >> v[i];
    deque<int> d;
    long long s = 0;
    for(int i = 1; i <= n; ++i)
    {   while(!d.empty() && v[d.front()] >= v[i]) d.pop_front();
        d.push_front(i);
        if(d.back() <= i - k) d.pop_back();
        if(i >= k)  s += v[d.back()];
    }
    out << s;
    return 0;
}