Cod sursa(job #2708699)

Utilizator pielevladutPiele Vladut Stefan pielevladut Data 19 februarie 2021 11:11:20
Problema Deque Scor 60
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.63 kb
#include <bits/stdc++.h>

using namespace std;

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

long long dq[5000005];
long long v[50000005];
int n, k;
long long ans;
int st, dr = -1;

int main()
{
    fin >> n >> k;
    for(int i = 1; i <= n; i ++)
    {
        fin >> v[i];
    }
    for(int i = 1; i <= n; i ++)
    {
        if(st <= dr && dq[st] == i - k)
        {
            st++;
        }
        while(st <= dr && v[i] <= v[dq[dr]])
            dr--;
        dq[++dr] = i;
        if(st <= dr && i >= k)
        {
            ans = ans + v[dq[st]];
        }
    }
    fout << ans << '\n';
}