Cod sursa(job #1504404)
Utilizator | Data | 17 octombrie 2015 18:21:47 | |
---|---|---|---|
Problema | Deque | Scor | 60 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.55 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("deque.in");
ofstream out("deque.out");
int a[5000000],dek[5000000],k,n;
long long suma;
int main()
{ in>>n>>k;
int i,prim=1,ultim=0;
for(i=1; i<=n; i++)
in>>a[i];
for(i=1; i<=n; i++)
{while(a[i]<=a[dek[ultim]] && prim<=ultim)
ultim--;
ultim++;
dek[ultim]=i;
if(dek[prim]<=i-k)
prim++;
if(i>=k)
suma+=a[dek[prim]];}
out<<suma;
in.close();
out.close();
return 0;
}