例63:C语言实现输出“魔方阵”。所谓魔方阵是指它的每一行,每一列和对角线之和均相等。
解题思路:魔方阵中各数的排列规律,魔方阵的阶数应该为奇数。
将1放在第1行中间一列
从2开始直到n*n止各数依次按下:每一个数存放的行比前一个数的行数减1,列数加1.
如果上一数的行为为1,则下一个数的行数为n
当上一个数的列数为n时,下一个数的列数应为1,行数减1
按上面的规则确定的位置上已有数,或上一个数是第1行第n列时,则把下一个数放在上一个数的下面
源代码演示:
#include<stdio.h>//头文件
int main()//主函数
{
int a[20][20]={
0};//定义二维数组
int i,j,n,k; //定义整型变量
i=1;//赋值
printf("请输入阶数为1~15之间的奇数:\n");//提示语句
scanf("%d",&n