Cod sursa(job #3218414)

Utilizator brianabucur11Briana Bucur brianabucur11 Data 27 martie 2024 10:17:30
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.7 kb
#include <bits/stdc++.h>

using namespace std;

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

const int NMAX=5e6+5;
deque <int> q;
long long 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;
    q.push_back(1);
    for (int i=1; i<=n; i++)
    {
        while (!q.empty() && v[i]<=v[q.back()])
            q.pop_back();
        q.push_back(i);
        if (i>=k)
        {
            while (!q.empty() && i-q.front()>=k)
                q.pop_front();
            sum+=v[q.front()];
        }
    }
    fout << sum;
}

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