N阶魔方阵


写出程序填写出N*N“魔方阵”的数值。所谓魔方阵是指这样的方阵,数据是正整数,从1开始,每个递增1,每个数据不重复出现,它的每一行、每一列和对角线之和均相等(N是奇数)。
input 

3

5

output

8  1   6
3   5  7
4   9   2

17 24 01 08 15
23 05 07 14 16
04 06 13 20 22
10 12 19 21 03
11 18 25 02 09

规律:
(1)将1放在第一行中间一列; (2)从2开始直到n×n止各数依次按下列规则存放;每一个数存放的行比前一个数的行数减1,列数加1(例如上面的三阶魔方阵,5在4的上一行后一列); (3)如果上一个数的行数为1,则下一个数的行数为n(指最下一行);例如1在第一行,则2应放在最下一行,列数同样加1; (4)当上一个数的列数为n时,下一个数的列数应为1,行数减去1。例如2在第3行最后一列,则3应放在第二行第一列; (5)如果按上面规则确定的位置上已有数,或上一个数是第一行第n列时,则把下一个数放在上一个数的下面。例如按上面的规定,4应该放在第1行第2列,但该位置已经被占据,所以4就放在3的下面; 

#include <cstdio>
#include <iostream>
#include <cstring>
#include <cstdlib>
using namespace std;

int main()
{
	int a[100][100]={0};
	int i,j;//记录当前行列
	int i1,j1;//记录前一个位置的行列
	int n,m;
	while(~scanf("%d",&n))
	{
		memset(a,0,sizeof(a));
		a[0][n/2]=1;
		i=0;
		j=n/2;
		for(m=2;m<=n*n;m++)
		{
           i1=i;
		   j1=j;
		   if(i==0)
			   i=n-1;
		   else
			   i--;
		   if(j==n-1)
			   j=0;
		   else
			   j++;
		   if(a[i][j]==0)
			   a[i][j]=m;
		   else
		   {
			   a[i1+1][j1]=m;
			   i=i1+1;
			   j=j1;
		   }   
			
		}
		for(i1=0;i1<n;i1++)
			for(j1=0;j1<n;j1++)
			{
				if(j1==n-1)
					printf("%d\n",a[i1][j1]);
				else
					printf("%d\t",a[i1][j1]);
			}

	}
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值