Pagini recente » Cod sursa (job #3254703) | Cod sursa (job #990650) | Cod sursa (job #229408) | Cod sursa (job #376408) | Cod sursa (job #235823)
Cod sursa(job #235823)
#include<stdio.h>
#define MAXN 5000010
int v[MAXN],d[MAXN],n,k,i,p,u;
long long rez;
int main(){
FILE *f=fopen("deque.in","r");
fscanf(f,"%d %d",&n,&k);
for(i=1;i<=n;i++){
fscanf(f,"%d",&v[i]);
}
fclose(f);
p=1;
u=1;
d[1]=1;
for(i=2;i<=n;i++){
while(d[p] <= i- k)
p++;
while(v[i] < v[d[u]] && p<=u)
u--;
u++;
d[u]=i;
if(i>=k){
rez+=(long long)v[d[p]];
}
}
FILE *g=fopen("deque.out","w");
fprintf(g,"%lld",rez);
fclose(g);
return 0;
}