Cod sursa(job #1104442)

Utilizator muresan_bogdanMuresan Bogdan muresan_bogdan Data 10 februarie 2014 20:00:42
Problema Deque Scor 25
Compilator cpp Status done
Runda Arhiva educationala Marime 0.63 kb
#include<iostream>
#include<fstream>
#include<deque>
using namespace std;

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

int n, k, v[5000001], i, sol;
deque<int> coada;

int main() {
    fin >> n >> k;
    for(i = 0; i < n; i++) {
        fin >> v[i];
        while(!coada.empty() && v[i] < v[coada.back()]) {
            coada.pop_back();
        }
        coada.push_back(i);
        if(coada.front() == i - k) {
            coada.pop_front();
        }
        if(i >= k - 1) {
            sol += v[coada.front()];
        }
    }
    fout << sol;
    fin.close();
    fout.close();
    return 0;
}