Cod sursa(job #1017403)

Utilizator acomAndrei Comaneci acom Data 27 octombrie 2013 19:08:53
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.52 kb
#include<fstream>
#include<deque>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
deque <int> q;
int n,k,a[5000005];
long long s;
int main()
{
    int i;
    fin>>n>>k;
    for (i=1;i<=n;++i)
        fin>>a[i];
    for (i=1;i<=n;++i)
        {
            while (!q.empty() && a[q.back()]>=a[i]) q.pop_back();
            q.push_back(i);
            if (q.front()==i-k) q.pop_front();
            if (i>=k) s+=(long long) a[q.front()];
        }
    fout<<s<<'\n';
    return 0;
}