Cod sursa(job #1203026)

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

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