Cod sursa(job #3359111)

Utilizator rareshdelasmBraica Rares Petrisor rareshdelasm Data 24 iunie 2026 16:36:23
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.78 kb
#include <bits/stdc++.h>
using namespace std;

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

int main() {
    int n, k;
    long long s = 0;
    int v[5000001];

    in >> n >> k;

    deque<int> dq; // ținem indici

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

        // eliminăm indicii care au ieșit din fereastră
        while (!dq.empty() && dq.front() <= i - k) {
            dq.pop_front();
        }

        // păstrăm deque-ul crescător după valori
        while (!dq.empty() && v[dq.back()] >= v[i]) {
            dq.pop_back();
        }

        dq.push_back(i);

        // după ce avem prima fereastră completă
        if (i >= k) {
            s += v[dq.front()];
        }
    }

    out << s;

    return 0;
}