Cod sursa(job #2068759)

Utilizator seby2341Mesca Sebastian seby2341 Data 18 noiembrie 2017 10:56:46
Problema Deque Scor 30
Compilator cpp Status done
Runda Arhiva educationala Marime 0.59 kb
#include <bits/stdc++.h>

using namespace std;
deque <int> q;
const int nmax=1e6*5+5;
int n,k,x,v[nmax];
long long s;
int main() {
    freopen("deque.in","r",stdin);
    freopen("deque.out","w",stdout);
    scanf("%d %d", &n, &k);

    for (int i = 1; i <= n; ++i)
        scanf("%d ", &v[i]);
    for (int i = 1 ; i <= n; ++i) {

        while (!q.empty() && v[i]<=v[q.back()])
            q.pop_back();
        q.push_back(i);

        if (i - k > 0 && v[q.front()] == v[i - k]) q.pop_front();
        if (i>=k) s+=1LL* v[q.front()];

    }
    printf("%lld", s);
    return 0;
}