Pagini recente » Cod sursa (job #2898298) | Cod sursa (job #2300296) | Cod sursa (job #926013) | Cod sursa (job #2643095) | Cod sursa (job #1280623)
#include<cstdio>
int n,m,i,j,a,ii,l,k,il,jl,p[510],x[11][510][510];
FILE *f,*g;
int maxim(int a,int b){
if(a>b)
return a;
return b;
}
int main(){
f=fopen("plantatie.in","r");
g=fopen("plantatie.out","w");
fscanf(f,"%d%d",&n,&m);
p[1]=0;
for(i=1;i<=509;i++){
p[i]=p[i/2]+1;
}
for(i=1;i<=n;i++){
for(j=1;j<=n;j++){
fscanf(f,"%d",&x[0][i][j]);
}
}
for(i=1;i<=p[n];i++){
a=1<<(i-1);
for(j=1;j<=n;j++){
for(ii=1;ii<=n;ii++){
x[i][j][ii]=maxim( x[i-1][j][ii], maxim( x[i-1][j][ii+a], maxim( x[i-1][j+a][ii], x[i-1][j+a][ii+a] ) ) );
}
}
}
/* for(i=1;i<=p[n];i++){
for(j=1;j<=n;j++){
for(ii=1;ii<=n;ii++){
fprintf(g,"%d ",x[i][j][ii]);
}
fprintf(g,"\n");
}
fprintf(g,"\n");
}*/
for(l=1;l<=m;l++){
fscanf(f,"%d%d%d",&i,&j,&k);
a=p[k]-1;
int s=maxim( x[a][i][j], maxim( x[a][i+k-(1<<a)][j], maxim( x[a][i][j+k-(1<<a)], x[a][i+k-(1<<a)][j+k-(1<<a)] ) ) );
fprintf(g,"%d\n",s);
}
fclose(f);
fclose(g);
return 0;
}