Pagini recente » Cod sursa (job #392371) | Cod sursa (job #306572) | Monitorul de evaluare | Rezultatele filtrării | Cod sursa (job #431335)
Cod sursa(job #431335)
#include<stdio.h>
FILE *f=fopen("deque.in","r");
FILE *g=fopen("deque.out","w");
#define M 5000010
long n,k,v[M],d[M];
void cit()
{
fscanf(f,"%ld%ld",&n,&k);
long i;
for(i=1;i<-n;++i)
fscanf(f,"%ld",&v[i]);
fclose(f);
}
void sol()
{
long long s=0;
long i,p=1,u=0;
for(i=1;i<=n;++i)
{
while(p<=u && v[i]<=v[d[u]]) u--;
d[++u]=i;
if(d[p]==i-k) p++;
if(i>=k) s+=v[d[f]];
}
fprintf(g,"%lld\n",s);
fclose(g);
}
int main()
{
cit();
sol();
return 0;
}