Cod sursa(job #2875750)

Utilizator indianu_talpa_iuteTisca Catalin indianu_talpa_iute Data 22 martie 2022 11:42:58
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.6 kb
#include <bits/stdc++.h>
#define MAXN 5000000
#define LL long long

using namespace std;

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

int n, k, arr[MAXN + 1];
LL sum = 0;
deque<int> minime;
int main() {
    fin >> n >> k;
    for (int i = 1; i <= n; i++)
        fin >> arr[i];
    for (int i = 1; i <= n; i++) {
        while (minime.size() && arr[i] <= arr[minime.back()])
            minime.pop_back();
        minime.push_back(i);
        if (minime.front() == i - k)
            minime.pop_front();
        if (i >= k)
            sum += arr[minime.front()];
    }

    fout << sum;
    return 0;
}