<style type="text/css">
<!--
@page
{margin:2cm}
p
{margin-bottom:0.21cm}
-->
</style>
一、幻方按照阶数可分成了三类,即奇数阶幻方、双偶阶幻方、单偶阶幻方。
二、奇数阶幻方(劳伯法)
奇数阶幻方最经典的填法是罗伯法。填写的方法是:
把1(或最小的数)放在第一行正中;按以下规律排列剩下的(n×n-1)个数:
(1)每一个数放在前一个数的右上一格;
(2)如果这个数所要放的格已经超出了顶行那么就把它放在底行,仍然要放在右一列;<style type="text/css">
<!--
@page
{margin:2cm}
p
{margin-bottom:0.21cm}
-->
</style>
(3)如果这个数所要放的格已经超出了最右列那么就把它放在最左列,仍然要放在上一行;
(4)如果这个数所要放的格已经超出了顶行且超出了最右列,那么就把它放在底行且最左列;
(5)如果这个数所要放的格已经有数填入,那么就把它放在前一个数的下一行同一列的格内。
例,用该填法获得的5阶幻方:
17
|
24
|
1
|
8
|
15
|
23
|
5
|
7
|
14
|
16
|
4
|
6
|
13
|
20
|
22
|
10
|
12
|
19
|
21
|
3
|
11
|
18
|
25
|
2
|
9
|
二、双偶数阶幻方(海尔法)
所谓双偶阶幻方就是当n可以被4整除时的偶阶幻方,即4K阶幻方。在说解法之前我们先说明一个“互补数”定义:就是在n阶幻方中,如果两个数的和等于幻方中最大的数与1的和(即n×n+1),我们称它们为一对互补数。如在三阶幻方中,每一对和为10的数,是一对互补数
;在四阶幻方中,每一对和为17的数,是一对互补数。
双偶数阶幻方最经典的填法是海尔法。填写的方法是:
以8阶幻方为例:
(1)先把数字按顺序填。然后,按4×4把它分割成4块(如图)
1
|
2
|
3
|
4
|
5
|
6
|
7
|
8
|
9
|
10
|
11
|
12
|
13
|
14
|
15
|
16
|
17
|
18
|
19
|
20
|
21
|
22
|
23
|
24
|
25
|
26
|
27
|
28
|
29
|
30
|
31
|
32
|
33
|
34
|
35
|
36
|
37
|
38
|
39
|
40
|
41
|
42
|
43
|
44
|
45
|
46
|
47
|
48
|
49
|
50
|
51
|
52
|
53
|
54
|
55
|
56
|
57
|
58
|
59
|
60
|
61
|
62
|
63
|
64
|
(2)每个小方阵对角线上的数字(如左上角小方阵部分),换成和它互补的数。
64
|
2
|
3
|
61
|
60
|
6
|
7
|
57
|
9
|
55
|
54
|
12
|
13
|
51
|
50
|
16
|
17
|
47
|
46
|
20
|
21
|
43
|
42
|
24
|
40
|
26
|
27
|
37
|
36
|
30
|
31
|
33
|
32
|
34
|
35
|
29
|
28
|
38
|
39
|
25
|
41
|
23
|
22
|
44
|
45
|
19
|
18
|
48
|
49
|
15
|
14
|
52
|
53
|
11
|
10
|
56
|
8
|
58
|
59
|
5
|
4
|
62
|
63
|
1
|
三、单偶数阶幻方(斯特拉兹法)
所谓单偶阶幻方就是当n不可以被4整除时的偶阶幻方,即4K+2阶幻方。如(n=6,10,14……)的幻方。
单偶数阶幻方最经典的填法是斯特拉兹法。填写的方法是:
以10阶幻方为例。这时,k=2。
(1)把魔方阵分为A,B,C,D四个象限,这样每一个象限肯定是奇数阶。用罗伯法,依次在A象限,D象限,B象限,C象限按奇数阶幻方的填法填数。
(2)在A象限的中间行、中间格开始,按自左向右的方向,标出k格。A象限的其它行则标出最左边的k格。将这些格,和C象限相对位置上的数互换位置。
(3)在B象限所有行的中间格,自右向左,标出k-1格。(注:6阶幻方由于k-1=0,所以不用再作B、D象限的数据交换),将这些格,和D象限相对位置上的数互换位置。
四、源代码如下,已加详细注释
分享到:
相关推荐
C#,任意阶幻方(Magic Square)的算法与源代码 幻方(Magic Square)是一种将数字安排在正方形格子中,使每行、列和对角线上的数字和都相等的方法。 幻方也是一种中国传统游戏。旧时在官府、学堂多见。它是将从一到...
用java代码实现幻方算法,比较简单,可以参考参考
幻方算法 神奇的幻方 幻方算法 神奇的幻方 幻方算法 神奇的幻方
由1~n²个连续正整数组成的n阶正方形,若它的每个横排,竖排,两条对角线的数字之和均相等,则此正方形可... 本人根据网上找到的构造算法,花了一天的休息时间将n阶幻方的生成算法利用C++实现,希望能对大家有所帮助。
幻方编程问题在C语言中屡见不鲜,也是计算机二级考试的难点,下面就奇数阶幻方算法
蓝桥杯算法学习笔记C++B组蓝桥杯算法学习笔记C++B组蓝桥杯算法学习笔记C++B组蓝桥杯算法学习笔记C++B组蓝桥杯算法学习笔记C++B组蓝桥杯算法学习笔记C++B组蓝桥杯算法学习笔记C++B组蓝桥杯算法学习笔记C++B组蓝桥杯...
笔记笔记笔记笔记笔记笔记笔记笔记笔记算法笔记算法笔记算法笔记算法笔记算法笔记
数据结构与算法分析学习笔记数据结构与算法分析学习笔记数据结构与算法分析学习笔记数据结构与算法分析学习笔记数据结构与算法分析学习笔记
学习笔记5:数据预处理与数据挖掘十大经典算法.docx学习笔记5:数据预处理与数据挖掘十大经典算法.docx学习笔记5:数据预处理与数据挖掘十大经典算法.docx学习笔记5:数据预处理与数据挖掘十大经典算法.docx学习笔记...
EM算法超详细学习笔记,很多书上都没有的,容易理解
数据结构与算法分析学习笔记(C++)chm 排版很好,代码直接能用,大牛写的,模板运用的很好
算法图解学习笔记,算法图解学习笔记,算法图解学习笔记,算法图解学习笔记
数据结构与算法分析学习笔记(C++),里面有很好的数据结构相关的代码,可以直接拷贝运行,chm格式,可以当工具使用
好东西 算法与数据结构学习笔记,全 不容错过
中软国际培训的学习笔记,很值得参考。学习java数据结构很有必要看看
《算法导论》学习笔记 有详细的和清晰的板书,非常好的东西
算法导论 学习笔记
智能算法学习笔记智能算法学习笔记智能算法学习笔记
幻方问题,一种很古老的对于幻方的研究,包括了n=3,你n>3的,奇数偶数的情况划分。