Cod sursa(job #2784870)

Utilizator dotyzebra775Papuc Stefan dotyzebra775 Data 17 octombrie 2021 16:39:19
Problema Deque Scor 30
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.55 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] <= d[ul])
            ul --;
        d[++ul] = a[i];
        if(d[pr] == a[i-k])
            pr ++;
        if(i >= k)
            s += d[pr];
    }
    fout << s;
    return 0;
}