Cod sursa(job #2230376)

Utilizator pinteastefanPintea Teodor Stefan pinteastefan Data 9 august 2018 21:37:34
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.76 kb
#include <fstream>
#include <deque>


using namespace std;

struct numbers{
    int value;
    int indice;
};

deque <numbers> deqq;


int main() {
    ifstream inputfile("deque.in");
    ofstream outputfile("deque.out");

    int n, k;
    inputfile >> n >> k;
    long long result = 0;
    for (int i = 0; i < n; i++)
    {
        numbers x;
        inputfile >> x.value;
        x.indice = i + k;
        while ( deqq.size() && deqq.back().value > x.value)
        {
            deqq.pop_back();
        }
        while (deqq.size() && deqq.front().indice <= i)
        {
            deqq.pop_front();
        }
        deqq.push_back(x);

        if(i >= k - 1){
            result += 1LL * deqq.front().value;
        }
    }

    outputfile << result;
    return 0;
}