Cod sursa(job #2121414)

Utilizator LXGALXGA a LXGA Data 3 februarie 2018 17:39:00
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.72 kb
#include <fstream>
#include <deque>
using namespace std;
deque<int> dq;
ifstream cin("deque.in");
ofstream cout("deque.out");
int v[5000001];
int main()
{
    long long n,i,j,s=0,k;
    cin>>n>>k;

    for(i=1;i<=n;i++)
    {
        cin>>v[i];
    }
    for(i=1;i<=k;i++)
    {
        while(!dq.empty() && v[dq.back()]>v[i])
            dq.pop_back();
        dq.push_back(i);
    }
    for(i=k+1;i<=n;i++)
    {
        s+=1LL*v[dq.front()];
        //right = i, left = i - k + 1
        if(dq.front()==i-k)
            dq.pop_front();
         while(!dq.empty() && v[dq.back()]>v[i])
            dq.pop_back();
        dq.push_back(i);
    }
    s+=1LL*v[dq.front()];
    cout<<s;
    return 0;
}