Cod sursa(job #3143065)

Utilizator RolandPetreanPetrean Roland RolandPetrean Data 27 iulie 2023 14:48:35
Problema Deque Scor 60
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.65 kb
#include <bits/stdc++.h>
using namespace std;

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

#define int long long

signed main() {
    int n, k;
    fin>>n>>k;

    vector<int> a(n+1);
    for (int i=1; i<=n; ++i) fin>>a[i];

    deque<int> q;
    for (int i=1; i<=k; ++i) {
        while (!q.empty() && a[q.back()] >= a[i]) q.pop_back();
        q.push_back(i);
    }

    int S = a[q.front()];
    for (int i=k+1; i<=n; ++i) {
        while (!q.empty() && q.front() <= i-k) q.pop_front();
        while (!q.empty() && a[q.back()] >= a[i]) q.pop_back();
        q.push_back(i);
        S += a[q.front()];
    }

    fout<<S;
}