Cod sursa(job #2671509)

Utilizator justin.stoicaJustin Stoica justin.stoica Data 12 noiembrie 2020 11:26:20
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.82 kb
#include <bits/stdc++.h>

using namespace std;
deque< pair <int, int> >coada;
int main()
{
    ifstream cin("deque.in");
    ofstream cout("deque.out");

    long long n, k, x, sum = 0;
    cin >> n >> k;
    for(int i = 1; i < k; i ++)
    {
        cin >> x;
        while (!coada.empty() && x <= coada.back().first)
        {
            coada.pop_back();
        }
        coada.push_back(make_pair(x, i));
    }
    for (int i = k; i <= n; ++i)
    {
        cin >> x;
        while (!coada.empty() && x <= coada.back().first)
        {
            coada.pop_back();
        }
        coada.push_back(make_pair(x, i));
        while (coada.front().second <= i - k)
        {
            coada.pop_front();
        }
            sum += coada.front().first;
    }
    cout << sum;
    return 0;
}