Cod sursa(job #2650776)

Utilizator KOTOAMATSUKAMIDistinguished Heavenly Gods KOTOAMATSUKAMI Data 20 septembrie 2020 09:00:40
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.56 kb
#include <bits/stdc++.h>
using namespace std;

int main () {
    ifstream fin ("deque.in");
    ofstream fout ("deque.out");

    int n, k;
    fin >> n >> k;

    deque <pair <int, int>> DQ;
    long long ans = 0;

    int i, x;
    for (i = 1; i <= n; i++) {
        fin >> x;
        while (!DQ.empty() && DQ.back().second >= x)
            DQ.pop_back();
        
        DQ.emplace_back(i, x);
        if (DQ.front().first == i - k)
            DQ.pop_front();
        
        if (i >= k)
            ans += DQ.front().second;
    }

    fout << ans;
    return 0;
}