Cod sursa(job #3150592)

Utilizator PescarusTanislav Luca Andrei Pescarus Data 17 septembrie 2023 16:45:45
Problema Deque Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.61 kb
#include <fstream>
#include <deque>

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


const int nmax = 5000005;
int n, l;
int a[nmax];

int main(){
    f >> n >> l;
    for(int i = 1; i <= n; i++){
      f >> a[i];
    }
    long long sum = 0;
    deque<int> dq;
    for(int i = 1; i <= n; i++){
      while(!dq.empty() && a[dq.back()] > a[i]){
        dq.pop_back();
      }
      dq.push_back(i);
      if(dq.front() <= i - l){
          dq.pop_front();
      }
      if(i >= l){
         sum += 1ll * a[dq.front()];
      }
       
    }
    g << sum << '\n';
}