Cod sursa(job #3150591)

Utilizator PescarusTanislav Luca Andrei Pescarus Data 17 septembrie 2023 16:44:50
Problema Deque Scor 25
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.6 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];
    }
    int 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 += a[dq.front()];
      }
       
    }
    g << sum << '\n';
}