Cod sursa(job #2575201)

Utilizator GabyD002Dobrita Gabriel GabyD002 Data 6 martie 2020 12:04:08
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.88 kb
#include <bits/stdc++.h>
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");

int n,k;
long long sol;
deque <pair<int,int>> dq;

int main()
{   f>>n>>k;
    for(int x,i=1; i<=k; i++)
    {   f>>x;
        if(dq.empty())
            dq.push_back(make_pair(x,i));
        else
        {   while(!dq.empty() && dq.back().first>x)
                dq.pop_back();
            dq.push_back(make_pair(x,i));
        }
    }
    sol+=dq.front().first;
    for(int x,i=k+1; i<=n; i++)
    {   f>>x;
        if(dq.front().second<=i-k)
            dq.pop_front();
        if(dq.empty())
            dq.push_back(make_pair(x,i));
        else
        {   while(!dq.empty() && dq.back().first>x)
                dq.pop_back();
            dq.push_back(make_pair(x,i));
        }
        sol=1LL*sol+dq.front().first;
    }
    g<<sol;
    g.close(); return 0;
}