Pagini recente » Cod sursa (job #1318082) | Cod sursa (job #2397680) | Cod sursa (job #2989804) | Cod sursa (job #1883875) | Cod sursa (job #2499847)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("plantatie.in");
ofstream fout("plantatie.out");
int p[25],lg[510];
int D[12][510][510];
int n,m,a,b,k,i,j;
void precalculare_puteri(){
p[0]=1;
for(int i=1; p[i-1] <= n;i++)
p[i]=p[i-1]*2;
}
void dinamica(){
for(int k=1;p[k]<=n;k++)
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++){
if(i+p[k]<=n+1 && j+p[k]<=n+1){
D[k][i][j]=max(D[k-1][i][j],max(D[k-1][i][j+p[k-1]],max(D[k-1][i+p[k-1]][j],D[k-1][i+p[k-1]][j+p[k-1]])));
}
}
}
void logaritm(){
lg[1]=0;
for(int i=2;i<600;i++)
lg[i]=lg[i/2]+1;
}
int main(){
fin>>n>>m;
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
fin>>D[0][i][j];
precalculare_puteri();
dinamica();
logaritm();
for(i=1;i<=m;i++){
fin>>a>>b>>k;
fout<<max(D[lg[k]][a][b],max(D[lg[k]][a][b+(k-p[lg[k]])],max(D[lg[k]][a+(k-p[lg[k]])][b],D[lg[k]][a+(k-p[lg[k]])][b+(k-p[lg[k]])])))<<"\n";
}
return 0;
}