Cod sursa(job #2264713)

Utilizator elenaisaiaElena Isaia elenaisaia Data 20 octombrie 2018 11:18:46
Problema Deque Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.78 kb
#include <iostream>
#include <fstream>
#include <vector>
#include <deque>

using namespace std;

long long n,k;
vector<long long>a;
deque<long long>d;

void citire()
{
    ifstream fin("deque.in");
    fin>>n>>k;
    long long x;
    for(long long i=0;i<n;++i)
    {
        fin>>x;
        a.push_back(x);
    }
}

void fctdeque()
{
    long long suma=0;
    d.push_back(0);
    for(long long i=1;i<n;++i)
    {
        while(a[d.back()]>=a[i])
            d.pop_back();
        d.push_back(i);
        if(i>=k-1)
        {
            if(d.back()-d.front()>=k)
                d.pop_front();
            suma+=a[d.front()];
        }
    }
    ofstream fout("deque.out");
    fout<<suma;
}

int main()
{
    citire();
    fctdeque();
    return 0;
}