魔方阵
来源:互联网 发布:手机在线升级软件 编辑:程序博客网 时间:2024/04/29 04:10
魔方阵(奇数阶)中各数的排列规律如下:
1、将“1”放在第一行中间一列;
2、从“2”开始直到n*n止各数依次按下列规则存放:每一个数存放的行比前一个数
的行数减1,列数加1;
3、如果上一数的行数为1,则下一个数的行数为n(指最下一行);
4、当上一个数的列数为n时,下一个数的列数应为1,行数减1;
5、如果按上面规则确定的位置上已有数,或上一个数是第1行第n列时,则把下一个
数放在上一个数的下面。
然后是偶数阶:
前一种:n=4*m+2, m为自然数
1)将n阶方阵分为四个小魔方阵ABCD如下排列:
B C
D A
因为n*n=4*(2*m+1)*(2*m+1),
记u=n/2=2*m+1,分为1~u*u,u*u+1~2*u*u,2*u*u+1~3*u*u,3*u*u+1~4*u*u
即在调用子函数的时候分别如下面传递参数:
A(0),B(u*u),C(2*u*u),D(3*u*u)
分别在ABCD中按照前面的填法把奇数阶填好(注意加上所传参数作为基数,每一个元素都要加上这个值),最后做如下交换:
(1)B中第0~(m-1)-1行中元素与C中相对应元素交换
(2)D中第(n-1)-m+1~(n-1)共m行的每行中的元素与A中相对应元素交换
(3)交换D:(u+m,m)与A中对应元素(矩阵中心值)
(4)交换D:(n-1,m)与A中对应元素(实际为矩阵最大值n*n)
所谓对应位置,指相对于小魔方阵的左顶角的相对的行列位置
上面的这些你可以用数学进行证明,利用魔方阵常数(注意n阶的和u阶的关系)
后一种:n=4*m,m为自然数
因为行列都是4的倍数,因而可以将整个矩阵分为每4*4的小矩阵。
先判断一个数是否在划为4*4小矩阵的对角线上,
如果在,则填该位置的数为n*n-i+1(i为该元素的相对位置,从1开始,比如n阶的第s行第t个元素则其i=s*n+t)
如果不在,则填上i。
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- 魔方阵
- How to make a resizable dialog bar in Microsoft Foundation Classes (MFC)
- 彻底解决南北互访速度慢的问题
- 16个知名英文科技博客媒体
- asp木马之攻与防
- 查询SQL SERVER表的字段信息的SQL
- 魔方阵
- FME(flash media encoder)发布音视频使用fms录制
- 学习c++的50条忠告
- 《往事随风》
- ICMP
- Tomcat 中通过 JNDI 配置访问数据库
- VS2005中引用tinyXML静态库引起的警告
- Hibernate中Criteria的完整用法
- 还原数据库时数据库路径出错的解决方法