Cod sursa(job #2716122)

Utilizator marateodorescu11Teodorescu Mara marateodorescu11 Data 4 martie 2021 18:52:37
Problema Deque Scor 0
Compilator c-64 Status done
Runda Arhiva educationala Marime 0.61 kb
#include <fstream>

using namespace std;

const int N = 5000000;

int v[N], dq[N + 1];

int main()
{
    ifstream in("deque.in");
    ofstream out("deque.out");

    int n, k, st, dr;
    long long s;
    in >> n >> k;
    st = 1, dr = s = 0;
    for (int i = 0; i < n; ++i)
    {
        in >> v[i];
        if (st <= dr && dq[st] == i - k)
            ++st; //pop back
        while (st <= dr && v[i] <= v[dq[dr]])
            --dr; //pop front
        dq[++dr] = i;
        if (i >= k - 1)
            s += v[dq[st]];
    }
    out << s;

    in.close();
    out.close();
    return 0;
}