1 2 3
8 9 4
7 6 5
![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)
#include<stdio.h>
#include<string.h>
int map[99][99];
int pi[4]={0,-1,0,1};
int pj[4]={-1,0,1,0};
int step=0;
void dfs(int fi,int fj)
{
int i,k;
for(i=0;i<=3;i++)
{
if(map[fi+pi[i]][fj+pj[i]]!=0)
continue;
for(k=1;;k++)
{
if(map[fi+pi[i]*k][fj+pj[i]*k]!=0)break;
map[fi+pi[i]*k][fj+pj[i]*k]=step++;
}
dfs(fi+pi[i]*(k-1),fj+pj[i]*(k-1));
}
return ;
}
int main()
{
int i,j,n;
while(scanf("%d",&n)!=EOF)
{
memset(map,1,sizeof(map));
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
{
map[i][j]=0;
}
}
step=1;
dfs(1,0);
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
{
printf("%d ",map[i][j]);
}
printf("\n");
}
}
return 0;
}