Cod sursa(job #1203006)

Utilizator azkabancont-vechi azkaban Data 30 iunie 2014 14:36:47
Problema Deque Scor 60
Compilator cpp Status done
Runda Arhiva educationala Marime 0.57 kb
#include <fstream>
#include <deque>
using namespace std;
ifstream cin("deque.in");
ofstream cout("deque.out");

deque <long long> Deque;

long long n,k,A[500013],sol;
 
int main()
{
  int i;
  cin>>n>>k; 
  for (i=1;i<=n;++i) cin>>A[i];
  for (i=1;i<=n;++i){
                     while (!Deque.empty() && A[i] <= A[Deque.back()]) Deque.pop_back();     
                     Deque.push_back(i);
                     if (Deque.front()==i-k) Deque.pop_front();
                     if (i>=k) sol+=A[Deque.front()];     
                    }
 cout<<sol;
 return 0;
}