Cod sursa(job #1552066)

Utilizator Emy1337Micu Emerson Emy1337 Data 17 decembrie 2015 10:38:21
Problema Deque Scor 25
Compilator cpp Status done
Runda Arhiva educationala Marime 0.78 kb
#include <iostream>
#include <fstream>
#include <deque>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");

const int MAXN = 5000100;


int values[MAXN];
deque< int > d;

void insert(int poz)
{
    while (!d.empty() && values[d.back()] > values[poz])
        d.pop_back();
    d.push_back(poz);
}

int get_min(int curIndex)
{
    while(!d.empty() && d.front() < curIndex)
        d.pop_front();
    return values[d.front()];
}

int n,k;

int main()
{
    fin>>n>>k;
    for (int i = 1; i <= n; ++i)
        fin >> values[i];

    for (int i = 1; i <= k; ++i)
        insert(i);

    int sum = 0;

    for (int i = k + 1; i <= n + 1; ++i)
    {
        sum += get_min(i - k);
        insert(i);
    }


    fout<<sum;

}