Cod sursa(job #3270685)

Utilizator inacioataCioata Ana Irina inacioata Data 24 ianuarie 2025 08:16:25
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.72 kb
#include <bits/stdc++.h>
using namespace std;
ifstream fin("deque.in");
ofstream fout("deque.out");
int n, a[5000005], k;
long long suma;
deque<int> q;

int main()
{
    int i, x;
    fin >> n >> k;
    for(i = 1; i <= n; i++)
        fin >> a[i];
    for(i = 1; i <= k; i++)
    {
        x = a[i];
        while(!q.empty() && x <= a[q.back()])
            q.pop_back();
        q.push_back(i);
    }
    suma = a[q.front()];
    for(i = k + 1; i <= n; i++)
    {
        x = a[i];
        while(!q.empty() && x <= a[q.back()])
            q.pop_back();
        q.push_back(i);
        if(q.front() == i - k) q.pop_front();
        suma += a[q.front()];
    }
    fout << suma << "\n";
    return 0;
}