数独快速随机出题的算法



C语言写的程序,2009年 i3 的处理器,出100道题,4.139秒。

算法步骤:
1、初始化数据。
2、向盘面中随机填入n个数。(这里的随机当然不是完全随机,不然盘面是无解的,n是多少,也要凭经验,考虑后续算法的时间)
3、求解当前盘面的解的个数。
 3.1、如果解的个数是1,则跳到6。
 3.2、如果解的个数是0,转到1。
 3.3、如果解的个数大于1,则求出两个解。
4、比较两个解中的数字差异,将相异的位置的数,任取一个,填入原始盘面中。
5、再次求解盘面中解的个数。
 5.1、如果解的个数大于1,求出两个解,跳至4。
 5.2、如果解的个数是1个,至6。
6、从当前盘面有数的位置,依次挖去一个。
 6.1、再次求解盘面中解的个数。
 6.1.1、如果是多个解,则把挖去的数补回,然后跳到6。
 6.1.2、如果是1个解,则跳至6。
7、输出当前盘面。

为了减少题目的难度,第6步可省。
100道题,4.139秒是执行了第6步,相当部分题目难度值超过了2000。当然,不执行第6步,出的题目要简单得多,出题时间也快很多。

 

好吧,贴几个超高难度的题目:

000860000005000000300000750060000409700130006000200000000000031180300000000702000
000300000206070000050000402000000023000600800831000045000080006009067000700200300
900030006058040000000009502500900003013005000070000000000004070042600000000720100
060000000004020580050090702007000000600100000010080904003000050900300400500240600
000060010006003200250080400030002800800004007000900041008000730000000000907040005
500600000003010000001370080097000130230000094000400700008007240962000000000080000

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
一、数独说明:数独由九行,九列组成,又分为顺序排列的九宫。每行、每列及每宫都包含九个格,九个格中填放1到9的不重复的数字。 二、自动计算原理(三步法): 1、基础法:找出空格中唯一可填的数字。方法是,先假设某空格中可填入九个数字,然后去掉所在行、所在列、所在宫中的已有数字。余下如果是唯一一个数字,那么这个数字就是结果 2、找唯一法:例如果某行、某列或某宫中只剩一个空格,那么九个数字中缺少的那个就是结果。 3、求唯余法:对于存在多个可能值的空格,循环取其中一个作为假设值,然后反复利用方法1和方法2去测试,如果出错冲突或导致别的空格无值可填时,说明假设的值是错误的。并对别剩余未找到唯一值的空格进行同样操作,直至找到可行的一个方案。 三、自动出题,是自动求解的反向过程,先给出答案,再组合题目: 1、数独易程度跟数独已知的数字个数有一定关系,但不是必然关系。可分为四级,根据网友“数独度分级”的文章https://wenku.baidu.com/view/af550ed51a37f111f1855ba0.html,结果是分布在0到1之间的一系列值,值越少越容易。 2、出题时,先利用随机数往81个空格中填入不冲突的值。方法是,因为对角线的三宫中的数字互不干扰,用随机数填充这三宫,然后根据数独规则要求随机填入另外六宫。 3、这是最终结果,然后根据易要求,随机将结果中的一定数量(可以用随机数)的方格清空。数独题已经形成。再根据网友提供的级别计算公式,计算形成的数独题的易程度是否符合要求。(此时的数独答案不是唯一的) 4、易程度具体计算公式是:两个空格所有可能值如果有依赖关系值为1,没依赖关系值为0。如此汇总所有空格之间的关系值为A,再除以空格个数B的18倍。即A/(18*B)。0—0.25为0级,0.25—0.5为1级,0.5—0.75为2级,0.75—1为3组。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值