Cod sursa(job #3156499)

Utilizator Paul281881818818181991919191881818Draghici Paul Paul281881818818181991919191881818 Data 11 octombrie 2023 17:53:49
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.59 kb
#include <fstream>
#define N 5000001
#include <deque>
std::ifstream fin("deque.in");
std::ofstream fout("deque.out");
int n, k, arr[N];
std::deque<int> D;
int main(){
    fin >> n >> k;
    for(int i = 1; i <= n; i++){
        fin >> arr[i];
    }
    int64_t sum = 0;
    for(int i = 1; i <= n; i++){
        while(!D.empty() && arr[i] <= arr[D.back()]){
            D.pop_back();
        }
        D.push_back(i);
        if(i - k >= 1 && D.front() == i - k){
            D.pop_front();
        }
        if(i - k >= 0)
            sum += arr[D.front()];
    }
    fout << sum ;
}