体现出来的就是 当前数字等于他到上下左右四个边的距离的最小值:实现这一计算过程的算法是:x=min(min(i,j),min(n-i+1,n-j+1));
// x=min(min(i,j),min(n-i+1,n-j+1));
#include<iostream>
#include <cstdio>
using namespace std;
int main()
{
int i, j, n;
while(cin >> n ,n!=0)
{
int x;
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
{
x=min(min(i,j),min(n-i+1,n-j+1));
printf("%d ",x);
}
printf("\n");
}
cout<<endl;
}
return 0;
}