Cod sursa(job #2332083)

Utilizator Anastasia11Susciuc Anastasia Anastasia11 Data 30 ianuarie 2019 13:04:55
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.56 kb
#include <iostream>
#include <fstream>
#include <deque>

using namespace std;

ifstream f("deque.in");
ofstream g("deque.out");

int n, k;
deque <int> dq; //pozitiile el
int a[5000002];
long long ans;

int main()
{
    f >> n >> k;
    for (int i = 1; i <= n; i++)
        f >> a[i];
    for (int i = 1; i <= n; i++)
    {
        while(dq.size()>=1 && a[dq.back()]>a[i]) dq.pop_back();
        dq.push_back(i);
        if(dq.front()==i-k) dq.pop_front();
        if(i>=k)
            ans+=a[dq.front()];
    }
    g << ans;
    return 0;
}