Cod sursa(job #3125642)

Utilizator Alexco2003Codarcea Alexandru-Christian Alexco2003 Data 3 mai 2023 22:37:45
Problema Deque Scor 25
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.88 kb
#include <iostream>
#include <fstream>

using namespace std;

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

    int N,K;
    f1 >> N >> K;
    int A[N], S = 0, d[N], front = 0, back = 0;

    for (int i = 0; i < N; i++)
    {
        f1 >> A[i];

        /// Remove elements from the back of the deque that are greater than or equal to A[i]
        while (back > front && A[d[back-1]] >= A[i])
        {
            back--;
        }

        /// Add current index to the back of the deque
        d[back++] = i;

        /// If the deque has K elements, remove the front element and add its value to the S
        if (i >= K-1)
        {
            if (d[front] == i-K)
            {
                front++;
            }
            S += A[d[front]];
        }
    }

    f2 << S;

    f1.close();
    f2.close();
    return 0;
}