Cod sursa(job #3301317)

Utilizator brianabucur11Briana Bucur brianabucur11 Data 24 iunie 2025 16:12:03
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.69 kb
#include <bits/stdc++.h>

using namespace std;

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

const int nmax=5e6+5;

deque <int> dq;
int n, k, v[nmax];

void read ()
{
    fin >> n >> k;
    for (int i=1; i<=n; i++)
        fin >> v[i];
}

void solve ()
{
    long long sum=0;
    for (int i=1; i<=n; i++)
    {
        while (!dq.empty() && v[i]<=v[dq.back()])
            dq.pop_back();
        dq.push_back(i);
        if (i>=k)
        {
            while (!dq.empty() && i-dq.front()>=k)
                dq.pop_front();
            sum+=v[dq.front()];
        }
    }
    fout << sum;
}

signed main()
{
    read();
    solve();
    return 0;
}