Pagini recente » Cod sursa (job #2101417) | Cod sursa (job #1262151) | Cod sursa (job #2466912) | Cod sursa (job #2174997) | Cod sursa (job #1957645)
#include<fstream>
#include<cmath>
using namespace std;
ifstream f("plantatie.in");
ofstream g("plantatie.out");
int n,t,i,j,k,x,y,d,a[501][501][10];
int maxim (int a,int b,int c, int d)
{
return max(max(a,b),max(c,d));
}
int main()
{
f>>n>>t;
for(i=1;i<=n;++i) for(j=1;j<=n;++j) f>>a[i][j][0];
for(k=1;k<=log2(n);++k)
{
d=(1<<(k-1));
for(i=1;i<=n-d;++i)
for(j=1;j<=n-d;++j)
a[i][j][k]=maxim(a[i][j][k-1],a[i+d][j][k-1],a[i][j+d][k-1],a[i+d][j+d][k-1]);
}
for(;t;--t)
{
f>>x>>y>>k;
d=(1<<((int)log2(k)-1));
g<<maxim(a[x] [y] [(int)log2(k)-1],
a[x+k-d][y] [(int)log2(k)-1],
a[x] [y+k-d][(int)log2(k)-1],
a[x+k-d][y+k-d][(int)log2(k)-1])<<'\n';
}
return 0;
}