Pagini recente » Cod sursa (job #2553402) | Cod sursa (job #138493) | Cod sursa (job #1203133) | Cod sursa (job #1112947) | Cod sursa (job #401860)
Cod sursa(job #401860)
#include<stdio.h>
int n,k,d[2][5001000];
int main()
{
FILE*f=fopen("deque.in","r");
fscanf(f,"%d%d",&n,&k);
int i,front,back,val,ok;
long long s=0;
for(i=front=back=0;i<n;++i)
{
fscanf(f,"%d",&val);
while(front<=back&&val<=d[1][back]&&i)
{--back;}
if(i)++back;
d[0][back]=i;
d[1][back]=val;
if(i-k>=d[0][front])
++front;
if(i>=k-1)
{
s+=d[1][front];
}
}
fclose(f);
FILE*g=fopen("deque.out","w");
fprintf(g,"%lld\n",s);
fclose(g);
return 0;
}