描述
【问题描述】
幻方是一种很神奇的 NN 矩阵:它由数字 1,2,3, … … , NN 构成,且每行、每列及两条对角线上的数字之和都相同。
当N为奇数时,我们可以通过以下方法构建一个幻方:
首先将 1 写在第一行的中间。
之后,按如下方式从小到大依次填写每个数K(K= 2,3, … , N*N ):
-
若 (K−1) 在第一行但不在最后一列,则将K填在最后一行,(K− 1) 所在列的右一列;
-
若 (K− 1) 在最后一列但不在第一行,则将K填在第一列,(K− 1) 所在行的上一行;
-
若 (K− 1) 在第一行最后一列,则将K填在 (K− 1) 的正下方;
-
若 (K− 1) 既不在第一行,也不在最后一列,如果 (K− 1) 的右上方还未填数, 则将K填在(K− 1)的右上方,否则将K填在 (K− 1) 的正下方
现给定N,请按上述方法构造 N*N 的幻方
输入样例:
3
输出样例:
8 1 6
3 5 7
4 9 2
这道题要对着题目给出的4个方法的步骤去写,就可以构成幻方了
#include <stdio.h>
#include <stdlib.h>
int main()
{
int n,k,x,y,j,i;
scanf("%d",&n);
int a[100][100];
x=0;y=n/2;
a[x][y]=1;//第一行的中间写1
for(k=2;k<=n*n;k++)//将2到n*n的数填到二维数组去
{
if(x==0&&y!=n-1){
x=n-1;y=y+1;}
else if(x!=0&&y==n-1){
x=x-1;y=0;}
else if(x==0&&y==n-1){
x=x+1;y=y;}
else if(a[x-1][y+1]==0)
{
x=x-1;y=y+1;
}
else{
x=x+1;
}
a[x][y]=k;
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("%d",a[i][j]);
if(j<n-1)
printf(" ");
}
printf("\n");
}
return 0;
}