数独技巧3.docx
《数独技巧3.docx》由会员分享,可在线阅读,更多相关《数独技巧3.docx(15页珍藏版)》请在冰豆网上搜索。
数独技巧3
数独技巧3
X翼删减法、剑鱼删减法
X翼删减法实例:
剑鱼删减法实例:
TurbotFish删减法
1楼
Turbot Fish介绍之前做个简单的铺垫,简单介绍一下强弱链的关系。
单链分为强链和弱链。
强链:
某行、列或宫只存在2个某候选数,这两个数就构成强链,两数非真即假。
这里用红线连接表示。
弱链:
某行、列或宫存在3个或3格以上某候选数,这些数就构成弱链,其中一个为真则其余为假;其中一个为假则不能判断其余的真假。
这里用蓝线连接表示。
根据强链两端数字,一个为真另一个为假的特性可以引申出某些三条连续单链组有排除候选数的情况。
“强-强-强链”和“强-弱-强”链都可以导致“长链”两端数字交叉处格中的该数被删除。
下边给出两种“三连链”的图:
(两图中“长链”形状可以互换)
说明:
“强-强-强链”由于链两端数非真即假的特性,标成红蓝两组,红为真则蓝为假,反之亦然。
“长链”两端也为一红一蓝,肯定有一个是真,所以排除掉共同区域格(橙色格)中的x。
“强-弱-强链”虽然不像“三强”中数字真假那么分明,但注意弱链的两端,弱链一端为真另一端也为假,这两端的数字分别连接强链,所以导致“长链”两端数同样是一真一假。
如果弱链两端均为假,则长链两端数都为真。
综上:
同样排除掉共同区域格(橙色格)中的x。
所以,可以看出“强-强-强链”与“强-弱-强链”在排除两端数字交叉区域数字的效果上是“等价”的。
turbot fish就是五条单链连成的环,有以下三种形状,左下边的形状酷似这种鱼,由此得名。
使用这种技巧就是找出这五条链中形成的“强-强-强链”或“强-弱-强链”。
再利用刚才已经说明的这两种长链的性质——无论另两条链强弱与否,删除掉这两条链交点处的候选数。
示意图:
下边是Turbot Fish删减法实例:
(还有另一种画法删除数字,你找到了吗?
)
最后注意一点,如果画出的“鱼”中只有一条强链或只有两条连续的强链,是无法利用这种技巧的。
因为没有“强-强-强链”和“强-弱-强链”作判断候选数真假的基础。
如果都理解了,可以应用到更长的单链中。
其实鱼的方法还是满简单的,以下为个人总结的步骤:
1、先确定四个宫,它们必须符合长方形/正方形的规格
2、接下来确定鱼尾巴,只有鱼尾巴是两个侯选数在一个宫中,并且不在一行/一列。
3、鱼尾巴确定了就可以开始画鱼了,分别是将鱼尾巴的两个节点横向/纵向延伸即可,而每个节点至少有两种延伸方式,所以同一条尾巴,至少有两种出现鱼的机会,并且这两种鱼型是有密切关联的。
Turbo Fish 多宝鱼(比目鱼)解法
可以简化成 摩天楼解法,观察实现比 X-Wing 还要简单呢!
不是所有的多宝鱼都可以转换成摩天楼,大约是四分之三,
如楼主 2F 的左图,2个强链。
右图就无法转换了!
针对数字N 找到2个强链,以5F的例子。
可以转成 下图的摩天楼
BUG删减法
BUG是Bivalue Universal Grave的缩写,按字面直接翻译是双壳全体坟墓。
使用该技巧必须遇到以下情况,即绝大多数格内都只含两个候选数,只有少数格内多余两个候选数。
如果非只含两个候选的格过多,建议不要试用该方法。
下边以只有1-2个格内非两个候选数的实例说明。
该方法证明起来比较麻烦,不过一旦理解定式后便能立即得出结果,所以很有必要掌握。
原理有点类似于唯一矩形删减法,即避免出现多解的情况。
见下图,只有一个格内含有2、3、5三个候选数。
假设该格内取值为2、5。
那么该题便出现了双解(两种答案都是正确的)。
为了避免这种情况的出现,该格内只能选3,这样就不会多解了,这个数一出,整题迎刃而解。
那么含三个候选数的格内到底取哪个候选数呢?
观察含三个候选数的格于之共行(列、宫)的几格。
如果同区有三格,另两格为xy、yz,那么这格内如果取xz就双解,所以取值就取xz之外的另一个数。
如果掌握这个定式就可以很快解题了,至于原理嘛,不一定非理解的很深刻O(∩_∩)O
下边看一下有两个格内含三个候选数的情况。
同样按照找xy、yz、xz的方法,先找到两个格内应该取哪个值。
这时出现了一个有趣的情况,两个都取6,说明该行的6一定在两格之中,所以该行其他格内的6被删除。
题目迎刃而解。
BUG+1有一个很好识别的办法:
1、所有未填写数格只有一个是有3个候选数的,其他都是2个候选数的
2、从3个候选数的数格里观察,如果某个数载行/列/宫都出现了3次,那么该数格就应该填写它了
唯一矩形删减法
这是一种较特殊的删减法,因为它运用的排除原理是数独的唯一性,如果你做的数独确定存在有唯一解,那么就放心运用这种技巧吧。
当然,绝大多数的数独都是唯一解,但不排除有些奇怪的题目存在多解求解的可能。
先牢记下边的非唯一解情况吧,不少人做一些多解的题也会出现这种情况,4格中每格取x或y都不算错误。
一个确定唯一解的数独不能出现上边的情况。
所以如果3格中都只有xy,另一格内除了xy以外还有其它候选数,则删掉这格中的xy,保留其它候选数。
理由:
如果这格还取值x或y,则构成上边的非
唯一解情况。
示意图a:
唯一矩形删减法b实例:
例B
最后一定要注意一点;
构成唯一矩形的四格必须同时存在于两行且同时存在于两列且同时存在与两宫中。
如果不满足这个条件,删除很可能是错误的。
例如:
四格如果分别在四个宫中,也符合两行两列,但没有符合两宫的要求,这时不要用唯一矩形删减法。
切记!
Y-wing删减法
Y-wing删减法:
某两格内x候选数形成强链,另两格内只有x、y两个候选数,且这两格内的x分别于以上含x的两格中的x形成链,无论强弱与否,含x、y的两格交叉处区域格内的y候选数被删除。
证明:
形成强链的x两格内必有一个x为真,所以与之有关系的含x、y的两格内必有一个y为真,得到含x、y的两格交叉处格内的候选数y被删除。
示意图:
实例:
红圈处3被删除
Remotepair删减法
该技巧有点类似于Turbot Fish 删减法(X链),使用候选数由单一的一个数改为了一个数对。
如果有偶数个只包含xy数对的格组成了一条链,那么这条链两端格交叉区域的格中删除x、y两个候选数。
证明:
假设长链的一端为x,可知另一端为y,反之亦然,即两端格内必有x和y,所以交叉区域格内要删除x、y两候选数。
也可以看做两条Turbot Fish (X链)可以参考Turbot Fish 的证明方法。
实例:
这一步有3处的候选数可以被删除
显性数对(数组)删减法
候选数的入门技巧,同一行、列或宫中出现数对(数组)则其它格不能在出现数对(数组)中的数字。
显性数对删减法实例: