Cod sursa(job #2044730)

Utilizator vd5420Doroftei Victor vd5420 Data 21 octombrie 2017 12:40:11
Problema Heapuri Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.82 kb
#include <iostream>
#include <fstream>
#include <algorithm>
#include <vector>
#include <bitset>
#include <stack>
#include <deque>
using namespace std;
ifstream in("date.in");
ofstream out("date.out");
long n,x,v[100001],sum,k;
deque <int> min_dq;
int main()
{
    int i;
    in>>n>>k;
    for(i=1;i<=n;i++)
        in>>v[i];
    for(i=1;i<=k;i++)
    {
        while(!min_dq.empty() and v[min_dq.back()]>v[i])
            min_dq.pop_back();
        min_dq.push_back(i);
    }
    sum+=v[min_dq.front()];
    for(i=k+1;i<=n;i++)
    {
        if(!min_dq.empty() and min_dq.front()<=i-k)
            min_dq.pop_front();
       while(!min_dq.empty() and v[min_dq.back()]>v[i])
            min_dq.pop_back();
        min_dq.push_back(i);
        sum+=v[min_dq.front()];
    }
    out<<sum;
    return 0;
}