Pagini recente » Cod sursa (job #1083102) | Cod sursa (job #530734) | Cod sursa (job #1078909) | Cod sursa (job #2051102) | Cod sursa (job #2291919)
#include <fstream>
using namespace std;
ifstream fin("plantatie.in");
ofstream fout("plantatie.out");
int l[5001];
int n,m,i,j,k,x,y,v[501][501][20];
int main(){
fin>>n>>m;
for(i=2;i<=n;i++){
l[i]=1+l[i/2];
}
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
fin>>v[i][j][0];
for(k=1;k<=l[n];k++){
x=(1<<(k-1));
for(i=1;i<=n;i++){
for(j=1;j<=n;j++){
v[i][j][k]=v[i][j][k-1];///aceeasi pozitie dim 2^k-1
if(i+x<=n && v[i+x][j][k-1]>v[i][j][k]){
v[i][j][k]=v[i+x][j][k-1];
}
if(j+x<=n && v[i][j+(1<<(k-1))][k-1]>v[i][j][k]){
v[i][j][k]=v[i][j+x][k-1];
}
if(i+x<=n && j+x<=n && v[i+x][j+x][k-1]>v[i][j][k])
v[i][j][k]=v[i+x][j+x][k-1];
}
}
}
for(;m;m--){
fin>>i>>j>>k;
x=v[i][j][l[k]];
y=(1<<l[k]);
if(v[i+k-y][j][l[k]]>x)
x=v[i+k-y][j][l[k]];
if(v[i][j+k-y][l[k]]>x)
x=v[i][j+k-y][l[k]];
if(v[i+k-y][j+k-y][l[k]]<x)
fout<<x<<"\n";
else
fout<<v[i+k-y][j+k-y][l[k]]<<"\n";
}
///fout<<v[4][5][2];
return 0;
}