Pagini recente » Borderou de evaluare (job #525087) | Clasamentul arhivei Infoarena Monthly | Cod sursa (job #2365410) | Cod sursa (job #1643960) | Cod sursa (job #2390012)
#include <fstream>
using namespace std;
ifstream fin("piese.in");
ofstream fout("piese.out");
int n,m,j,nr,i,l,c,k,v[501][501];
int main()
{
fin>>n>>m;
for(i=1; i<=n; i++)
{
for(j=1; j<=m; j++)
{
if(v[i][j]==0)
{
++nr;
k=1;
while(i+2*k-1<=n&&j+2*k-1<=m) k*=2;
for(l=i; l<i+k; l++)
for(c=j; c<j+k; c++) v[l][c]=nr;
}
}
}
fout<<nr<<'\n';
for(i=1; i<=n; i++)
{
for(j=1; j<=m; j++)
{
fout<<v[i][j]<< " ";
}
fout<<'\n';
}
return 0;
}