Cod sursa(job #781133)

Utilizator SebiSebiPirtoaca George Sebastian SebiSebi Data 23 august 2012 15:23:37
Problema Plantatie Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.75 kb
#include<iostream>
#include<fstream>
using namespace std;
const int LMAX = 8;
int a[LMAX+1][501][501],lg[501];
int main ()
{
	int n,m,i,j,k,nr,l;
	ifstream f("plantatie.in");
	ofstream g("plantatie.out");
	f>>n>>m;
	for(i=1;i<=n;i++) 
		for(j=1;j<=n;j++)
			f>>a[0][i][j];
	lg[1]=0;
	for(i=2;i<=n;i++)
		lg[i]=lg[i/2]+1;
	for(k=1;(1<<k)<=n;k++)
		for(i=1;i<=n-(1<<k)+1;i++)
			for(j=1;j<=n-(1<<k)+1;j++)
				a[k][i][j]=max(max(a[k-1][i][j],a[k-1][i][j+(1<<(k-1))]),max(a[k-1][i+(1<<(k-1))][j],a[k-1][i+(1<<(k-1))][j+(1<<(k-1))]));
	for(nr=1;nr<=m;nr++) {
        f>>i>>j>>l;
        k=lg[l];
		g<<max(max(a[k][i][j],a[k][i][j-(1<<k)+l]),max(a[k][i-(1<<k)+l][j],a[k][i-(1<<k)+l][j-(1<<k)+l]))<<'\n';
	}
	f.close();
	g.close();
	return 0;
}