Cod sursa(job #3004009)

Utilizator AlexDavid26Alex Bleotu AlexDavid26 Data 16 martie 2023 08:36:26
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.66 kb
#include <iostream>
#include <deque>
#include <fstream>

using namespace std;

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

int arr[5000002];

int main() {
    int n, k;
    long long sum = 0;

    fin >> n >> k;
    for (int i = 0; i < n; i++)
        fin >> arr[i];

    deque<int> sequence;

    for (int i = 0; i < n; i++) {
        while (!sequence.empty() && arr[i] <= arr[sequence.back()])
            sequence.pop_back();

        sequence.push_back(i);

        if (sequence.front() == i - k)
            sequence.pop_front();

        if (i >= k - 1)
            sum += 1LL * arr[sequence.front()];
    }

    fout << sum;
}