Cod sursa(job #2499849)

Utilizator radugnnGone Radu Mihnea radugnn Data 26 noiembrie 2019 20:19:47
Problema Plantatie Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 1.04 kb
#include <bits/stdc++.h>
using namespace std;
ifstream fin("plantatie.in");
ofstream fout("plantatie.out");
int p[25],lg[610];
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;
}