Pagini recente » Cod sursa (job #1054615) | Cod sursa (job #1231665) | Cod sursa (job #198974) | Cod sursa (job #2144451) | Cod sursa (job #188255)
Cod sursa(job #188255)
#include<stdio.h>
struct asfs {int v,p;}d[1000000];
int i,v[1000005],n,k,p,u,max,a,b;
int main(){
FILE *f=fopen("secventa.in","r");
fscanf(f,"%d %d",&n,&k);
for(i=1;i<=n;i++)
fscanf(f,"%d",&v[i]);
fclose(f);
p=u=1;
d[1].v=v[1];
d[1].p=1;
max=-32000;
for(i=2;i<=n;i++){
while(p<=u&&d[p].p<=i-k)
p++;
while(p<=u&&d[u].v>v[i])
u--;
u++;
d[u].p=i;
d[u].v=v[i];
if(i>=k&&d[p].v>max){
a=d[u].p-k+1;
max=d[p].v;
}
}
b=a+k-1;
while(a>1 && v[a-1]>=max)
a--;
FILE *g=fopen("secventa.out","w");
fprintf(g,"%d %d %d",a,b,max);
fclose(g);
return 0;
}