DLX 求解数独

原文链接: DLX 求解数独

上一篇: cocos 入门拖拽游戏

下一篇: rxjs 冷热两种模式

https://www.cnblogs.com/grenet/p/3145800.html

https://blog.csdn.net/xiahn1a/article/details/50858957

https://www.jianshu.com/p/93b52c37cc65

https://blog.csdn.net/zhangjianjunab/article/details/83688681

http://blog.gssxgss.me/use-dlx-to-solve-sudoku-1/

https://blog.csdn.net/moguxiaozhe/article/details/47998443

https://blog.csdn.net/WhereIsHeroFrom/article/details/79220897

基本上还是有很大提升的, 相比于使用位的搜索算法, 空间和时间上有很大的优势, 不管是有解还是无解都很快

两个优化点

1, 每次选择含1数目最少的列

2, 尽量将1最多的行放在前面

3, 构造行的时候尽量用条件约束构造尽可能少的行, 用行, 列和九宫去约束可能性

另外列的顺序不会影响解的结果, 但是行的顺序会影响解的映射

行列的变化和选取影响搜索的路径, 即尽量在一开始选取可能比较少的, 因为这样在删除行的时候可以删除大量无效状态

up-467f825ae6bdb95f12c63764a020c863657.png

添加一些剪枝, DLX算法的优势更大了

up-760b2fc4a1739e598f046c6f3b9f22a1c85.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值