Cod sursa(job #1780493)

Utilizator d0rina2011Craciun Dorina d0rina2011 Data 16 octombrie 2016 12:07:21
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.61 kb
#include <iostream>
#include <fstream>
#include <cstring>
#include <climits>
#include <deque>
#define dmax 5000001

using namespace std;

ifstream fin ("deque.in");
ofstream fout ("deque.out");

deque<int> d;
long long v[dmax];

int main()
{
    long long n, k, s = 0, i;
    char c;
    fin>>n>>k;
    for(i = 1; i <= n; ++i)
        fin>>v[i];
    for(i = 1; i <= n; ++i){
        while (!d.empty() and v[i ]<= v[ d.back() ])
            d.pop_back();
        d.push_back(i);
        if( d.front() <= i-k) d.pop_front();
        if( i >= k) s += v[d.front()];
    }
    fout<<s;
    return 0;
}