匿名用户
1级
2013-11-03 回答
#include
int main()
{
int a[20][20]={0},i,j,n;
i=1;
printf("请输入一个数");
scanf("%d",&n);//输入魔方阵的维度n
j=n/2+1; // j是维度的一半加1.
a[i][j]=1; //确定第一排的中间一个数为1
for(int k=2;k<=n*n;k++)//已经确定1的位置了,再循环确定2~n*n的位置
{
i=i-1; //挪位,竖排往上挪一位。
j=j+1; //挪位,横排往右挪一位。
if((i<=0)&&(j<=n)) //如果竖排挪到顶,同时横排还没有超过最右,竖排就到从最下再继续。
i=n;
if((i<=0)&&(j>n)) //如果竖排挪到顶,同时横排超过最右,竖排往下挪两位,横排往左移一位。
{
i=i+2;
j=j-1;
}
if(j>n) //如果只有横排超过最右,横排挪到左边第二行。
{
j=1;
}
if(a[i][j]==0) a[i][j]=k; //如果这个位置还没有赋值,那么赋值为k。
else //已经赋值过了。那么竖排往下挪两位,横排往左移一位,再赋值为k。
{
i=i+2;
j=j-1;
a[i][j]=k;
}
}
for(i=1;i<=n;i++) //循环输出位置。
{
for(j=1;j<=n;j++)
printf("%5d",a[i][j]);
printf("\n");
}
}魔方阵有一定画法,先取一点,然后往左上、右下、右上、左下,任意选一个方向填数字就可以了。
这个是其中一个画法:
1)将1填入第一行中间;
2)将每个数填在前一个数的右上方。
3)若该位置超出最上行,则改填在最下行的对应位置;
4)若该位置超出最右列,则该填在最左列的对应行位置;
5)若某元素填在第一行最右列,下一个数填在该数同列的下一行;
6)若某数已填好,但其右上角已填了其他数据,则下一个数填在该数同列的下一行位置。