Cod sursa(job #3004918)

Utilizator PopaBiancaPopa Bianca Daniela PopaBianca Data 16 martie 2023 18:00:42
Problema Deque Scor 60
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.67 kb
#include <bits/stdc++.h>

using namespace std;

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

int n, k, x;
long long ans;

deque <pair<long long, int>> dq;

int main()
{
    fin >> n >> k >> x;
    dq.push_back(make_pair(x, 1));
    for(int i = 2; i <= n; i++)
    {
        fin >> x;
        if (!dq.empty() && dq.front().second <= i-k)
            dq.pop_front();
        while (!dq.empty() && dq.back().first > x )
        {
            dq.pop_back();
        }
        dq.push_back(make_pair(x, i));
        if (i >=k )
        {
            ans += dq.front().first;
           // cout << dq.front().first << " ";
        }
            
    }
    fout << ans;
    return 0;
}