Cod sursa(job #1262939)

Utilizator ZimmyZimmermann Erich Zimmy Data 13 noiembrie 2014 18:28:04
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.62 kb
#include <fstream>
#include <deque>
#define N 5000010
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
long long sol;
int n,i,x[N],k;
deque <int> q;
int main()
{
    fin>>n>>k;
    for(i=1;i<k;i++)
    {
        fin>>x[i];
        while(q.size()&&x[i]<=x[q.back()])
            q.pop_back();
        q.push_back(i);
    }
    for(i=k;i<=n;i++)
    {
        fin>>x[i];
        while(q.size()&&x[i]<=x[q.back()])
            q.pop_back();
        q.push_back(i);
        if(q.front()==i-k)
            q.pop_front();
        sol+=x[q.front()];
    }
    fout<<sol;
    return 0;
}