Cod sursa(job #2784886)

Utilizator dotyzebra775Papuc Stefan dotyzebra775 Data 17 octombrie 2021 17:28:25
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.56 kb
#include <fstream>
#define N 5000005
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");

int a[N], d[N];

int n, k;

int pr, ul;

int main()
{
    int i;
    long long s = 0;
    fin >> n >> k;
    for(i = 1; i <= n; ++ i)
        fin >> a[i];
    pr = 1; ul = 0;
    for(i = 1; i <= n; ++ i)
    {
        while(pr <= ul && a[i] <= a[d[ul]])
            ul --;
        d[++ul] = i;
        if(d[pr] == i-k)
            pr ++;
        if(i >= k)
            s += 1LL*a[d[pr]];
    }
    fout << s;
    return 0;
}