Cod sursa(job #364920)
| Utilizator | Data | 17 noiembrie 2009 14:07:25 | |
|---|---|---|---|
| Problema | Secventa | Scor | 0 |
| Compilator | cpp | Status | done |
| Runda | Arhiva de probleme | Marime | 0.5 kb |
#include<stdio.h>
int d[500100],v[500100],n,k,i,bi,bf,p,u,max;
int main(){
FILE*f=fopen("secventa.in","r");
FILE*g=fopen("secventa.out","w");
fscanf(f,"%d %d\n",&n,&k);
for(i=1;i<=n;i++)
fscanf(f,"%d",&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)
if(v[d[p]]>max){
max=v[d[p]];
bi=i-k+1;
bf=i;
}
}
fprintf(g,"%d %d %d",bi,bf,max);
fclose(f);fclose(g);
return 0;
}
