Cod sursa(job #2349436)

Utilizator Iulia14iulia slanina Iulia14 Data 20 februarie 2019 14:34:25
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.92 kb
#include <fstream>

using namespace std;
ifstream cin ("deque.in");
ofstream cout ("deque.out");
#include <deque>
deque <int> d1;
deque <int> d2;
int v[5000005];
int main()
{
    long long n,k,i,s=0;
    cin>>n>>k;
    for (i=1;i<=n;i++)
    {
        cin>>v[i];
        if (i<=k)
        {
            while (!d1.empty()&&v[i]<d1.back())
            {
                d1.pop_back();
                d2.pop_back();
            }
            d1.push_back(v[i]);
            d2.push_back(i);
        }
    }
    s+=d1.front();
    for (i=k+1;i<=n;i++)
    {
        while (d2.front()<=i-k)
        {
            d2.pop_front();
            d1.pop_front();

        }
        while (!d1.empty()&&v[i]<d1.back())
        {
            d1.pop_back();
            d2.pop_back();
        }
        d1.push_back(v[i]);
        d2.push_back(i);
        s+=d1.front();
    }
    cout<<s;
    return 0;
}