Cod sursa(job #2630310)

Utilizator gasparrobert95Gaspar Robert Andrei gasparrobert95 Data 25 iunie 2020 11:33:43
Problema Deque Scor 5
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.9 kb
#include <iostream>
#include <fstream>
#include <deque>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
deque <int> q;
int n, k, el, v[5000005];
long long sum;

int main() {
    fin >> n >> k;
    for (int i = 1; i <= n; ++i)
        fin >> v[i];
    for (int j = 1, i = 1; j <= n; ++j) {
        if (j > k) {
            ++i;
            if (!q.empty()) {
                sum += v[q.front()];
                while (q.front() < i) {
                    q.pop_front();
                    if (q.empty())
                        break;
                }
            }
        }
        if (!q.empty())
            while (v[j] < v[q.back()]) {
                q.pop_back();
                if (q.empty())
                    break;
            }
        q.push_back(j);
    }
    if (!q.empty())
        sum += v[q.back()];
    fout << sum;
    return 0;
}