Pagini recente » Cod sursa (job #613794) | Cod sursa (job #2666900) | Cod sursa (job #413023) | Cod sursa (job #2365492) | Cod sursa (job #250542)
Cod sursa(job #250542)
#include <stdio.h>
#define DIM 5000001
int A[DIM];
int D[DIM];
int n,k,i,p,u;
long long s;
int main(){
FILE *f = fopen("deque.in","r");
fscanf(f,"%d %d",&n,&k);
for (i=1;i<=n;i++){
fscanf(f,"%d",&A[i]);
}
p=u=1;
D[u]=1;
for (i=2;i<=n;i++){
while (p<=u && A[i]<=A[D[u]])
u--;
D[++u] = i;
if (D[p]<i-k+1)
p++;
if (i>=k) {
s+=A[D[p]];
}
}
fclose(f);
FILE *g = fopen("deque.out","w");
fprintf(g,"%lld\n",s);
fclose(g);
return 0;
}