幻方常规求解方法汇总
来源:互联网 发布:三星网络摄像机密码 编辑:程序博客网 时间:2024/05/19 12:11
没法,组合数学还考幻方构造。这东西不看解法真不会写,虽然没见有啥用,但还是记录下,免得日后再找。按目前填写幻方的方法,是把幻方分成了三类,即奇数阶幻方、双偶阶幻方、单偶阶幻方。下面按这三类幻方,列出最常用解法(考试用,不求强大,只求有效!)。
奇数阶幻方(罗伯法)
奇数阶幻方最经典的填法是罗伯法。填写的方法是:
把1(或最小的数)放在第一行正中; 按以下规律排列剩下的(n×n-1)个数:
1、每一个数放在前一个数的右上一格;
2、如果这个数所要放的格已经超出了顶行那么就把它放在底行,仍然要放在右一列;
3、如果这个数所要放的格已经超出了最右列那么就把它放在最左列,仍然要放在上一行;
4、如果这个数所要放的格已经超出了顶行且超出了最右列,那么就把它放在前一个数的下一行同一列的格内;
5、如果这个数所要放的格已经有数填入,那么就把它放在前一个数的下一行同一列的格内。
例,用该填法获得的5阶幻方:
双偶数阶幻方(对称交换法)
所谓双偶阶幻方就是当n可以被4整除时的偶阶幻方,即4K阶幻方。在说解法之前我们先说明一个“互补数”定义:就是在 n 阶幻方中,如果两个数的和等于幻方中最大的数与 1 的和(即 n×n+1),我们称它们为一对互补数 。如在三阶幻方中,每一对和为 10 的数,是一对互补数 ;在四阶幻方中,每一对和为 17 的数,是一对互补数 。
双偶数阶幻方的对称交换解法:
先看看4阶幻方的填法:将数字从左到右、从上到下按顺序填写:
以8阶幻方为例:
(1) 先把数字按顺序填。然后,按4×4把它分割成4块(如图)
单偶数阶幻方(象限对称交换法)
以n=10为例,10=4×2+2,这时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象限的数据交换), 将B象限标出的这些数,和D象限相对位置上的数进行交换,就形成幻方。
下面是6阶幻方的填法:6=4×1+2,这时k=1
注:摘自http://tanglizeng.blog.163.com/,仅保留了最简单有效解法
- 幻方常规求解方法汇总
- (ZT)幻方常规解法汇总
- 幻方问题的 求解方法
- 幻方求解
- 幻方问题求解
- [Java]常规方法和筛法求解素数效率对比
- logistic回归模型【求解参数方法汇总】
- 幻方的故事与求解
- 一元三次方求解
- 常规用法-汇总(一)
- [LeetCode] Scramble String (非常规DP求解)
- 构造了一种难解的非线性一阶常微分方程,边值特殊;但可用非常规方法求解
- 常规测试方法
- 常规测试方法
- 常规测试方法
- 常规测试方法
- 常规数据类型检测方法
- String的常规方法
- KMP算法之我见
- Editing a Book UVA
- Java中Filter、Listener,拦截器的学习,listener、 filter、servlet 加载顺序及其详解
- Redis快速入门
- Ubuntu16.04安装配置JDK1.7
- 幻方常规求解方法汇总
- SpringMVC学习(4): HiddenHttpMethodFilter
- C++实验4
- JSP编写规范
- 2017.04.21起每日完成
- javaday47_IO流_转换流的规律,指定编码表
- 5.网络层(3)---路由选择协议
- 项目中使用的git工作流
- 递归实现汉诺塔问题