Pagini recente » Cod sursa (job #338963) | Cod sursa (job #1954269) | Cod sursa (job #803033) | Cod sursa (job #1031268) | Cod sursa (job #364919)
Cod sursa(job #364919)
#include<stdio.h>
int s,n,k,v[5000100],d[5000100],p,u,i;
int main(){
FILE*f=fopen("deque.in","r");
FILE*g=fopen("deque.out","w");
fscanf(f,"%d %d\n",&n,&k);
for(i=1;i<=n;i++)
fscanf(f,"%d\n",&v[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[p]];
fprintf(g,"%d ",d[p]);
}
fprintf(g,"\n%d",s);
fclose(f);fclose(g);
return 0;
}