Cod sursa(job #1674568)

Utilizator serbanSlincu Serban serban Data 4 aprilie 2016 18:59:09
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.6 kb
#include <iostream>
#include <fstream>
#include <deque>
#define pii pair<int, int>
using namespace std;

pii q[5000005];
long long ret;

int main()
{
    ifstream f("deque.in");
    ofstream g("deque.out");
    int n, k, x, l = 1;
    f >> n >> k;
    for(int i = 1; i <= n; i ++) {
        f >> x;
        while(q[0].first >= l && q[q[0].first].first > x)
            q[0].first --;
        q[++ q[0].first] = {x, i};
        if(i >= k) {
            while(q[0].first >= l && q[l].second <= i - k) l ++;
            ret += q[l].first;
        }
    }
    g << ret << "\n";
    return 0;
}