Cod sursa(job #1116672)

Utilizator Dddarius95Darius-Florentin Neatu Dddarius95 Data 22 februarie 2014 19:00:33
Problema Deque Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.56 kb
// deque - O(1) amortizat
#include <fstream>
#include <deque>
#define Nmax 5000099
using namespace std;
ifstream f("deque.in");
ofstream g("deque.out");

int N,K,v[Nmax];
long long sol;
deque < int > dq;

int main()
{
     f>>N>>K;
     for(int i=1;i<=N;++i)
     {
          f>>v[i];
          while(!dq.empty() && v[i]<=v[dq.back()])dq.pop_back();
          dq.push_back(i);
          if(dq.front()==i-K)dq.pop_front();
          if(i>=K)
               sol+=v[dq.front()];
     }
     g<<sol<<'\n';
     f.close();g.close();
     return 0;
}