Cod sursa(job #2568633)

Utilizator norryna07Alexandru Norina norryna07 Data 4 martie 2020 08:50:57
Problema Deque Scor 60
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.57 kb
#include <bits/stdc++.h>
#define N 5000200
using namespace std;

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

deque <long long> dq;
long long a[N], n, k;

int main()
{
    fin>>n>>k;
    for (int i=1; i<=n; ++i)
        fin>>a[i];
    fin.close();

    long long sum=0;

    for (int i=1; i<=n; ++i)
    {
        while (!dq.empty() && a[i]<=a[dq.back()]) dq.pop_back();
        dq.push_back(i);
        if (dq.front()==i-k) dq.pop_front();

        if (i>=k) sum+=a[dq.front()];
    }
    fout<<sum<<'\n';
    fout.close();
    return 0;
}