Cod sursa(job #2644050)

Utilizator nTropicManescu Bogdan Constantin nTropic Data 22 august 2020 23:32:51
Problema Deque Scor 60
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.69 kb
#include <bits/stdc++.h>

using namespace std;

long long n, k, sum, v[5000005];
deque<long long> dq;

int main() {
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);

    freopen("deque.in", "r", stdin);
    freopen("deque.out", "w", stdout);

    cin >> n >> k;

    for (int i = 1; i <= n; i++) {
        cin >> v[i];
    }

    for (int i = 1; i <= n; i++) {
        while (!dq.empty() && (v[dq.back()] >= v[i])) {
            dq.pop_back();
        }

        dq.emplace_back(i);

        if (dq.front() == i - k) {
            dq.pop_front();
        }

        if (i >= k) {
            sum += v[dq.front()];
        }
    }

    cout << sum;
}