python实现自动解数独小程序
作者:wu_xying 发布时间:2023-03-28 12:15:19
标签:python,解数独
跟朋友最近聊起来数独游戏,突发奇想使用python编写一个自动计算数独解的小程序。
数独的规则不再过多阐述,在此描述一下程序的主要思路:
(当前程序只针对于简单的数独,更复杂的还待深入挖掘)
1.计算当前每个空格可能的取值集合,并将空格顺序值对应取值集合置于字典中;
2.对取值集合位数为1,即空格处为单一取值的进行赋值,(填入动作),重复1刷新字典直到字典为空位置;
当前实现如下:
1.将数独输入列表中,并定义函数count_candinate_number(j)根据数独规则计算每一个为0的位置的当前可能取值:
#编辑数独题目,将题目输入列表中
question = [6,0,7,0,0,0,9,0,3,
0,0,8,0,0,7,0,0,0,
3,0,0,0,8,2,0,7,5,
0,1,2,3,0,5,0,0,0,
0,0,6,0,0,0,5,0,0,
0,0,0,4,0,6,7,1,0,
2,6,0,7,4,0,0,0,8,
0,0,0,8,0,0,6,0,0,
7,0,5,0,0,0,1,0,9]
# print(question[0])
#返回当前数独为0的空格中所有可能取值
def count_candidate_number(j):
exist_all_number = [] #当前横竖大方格内所有出现的数字集
candidate_number = [] #该方格内所有的数字候选集
SD_Row = int(j) // 9 #行
SD_Column = int(j) % 9 #列
#用迭代器写
exist_all_number_part1 = [question[i+SD_Row*9] for i in range(9)] #横-出现的所有数字集
exist_all_number_part2 = [question[i*9+SD_Column] for i in range(9)] #竖-出现的所有数字集
exist_all_number_part3 = [question[((j//9)//3)*27+((j % 9)//3)*3+i] for i in range(3)]+[question[((j//9)//3)*27+((j % 9)//3)*3+9+i] for i in range(3)]+[question[((j//9)//3)*27+((j % 9)//3)*3+18+i] for i in range(3)] #大方块-出现的所有数字集
exist_all_number = list(set(exist_all_number_part1+exist_all_number_part2+exist_all_number_part3)) #对出现所有的数字集组合及去重
# print(exist_all_number)
#用循环写
# for i in range(9):
# if question[i+SD_Row*9] not in exist_all_number:
# exist_all_number.append(question[i+SD_Row*9])
# if question[i*9 + SD_Cloumn] not in exist_all_number:
# exist_all_number.append(question[i*9 + SD_Cloumn])
# # print(exist_all_number)
#迭代器写
candidate_number = [i for i in range(1, 10) if i not in exist_all_number] #对可能取值进行迭代输出
#用循环写
# for i in range(1,10):
# if i not in exist_all_number:
# candidate_number.append(i)
# print(candidate_number)
return candidate_number
2.定义函数求解对应每个为0的位置的可能求解,并将位置信息与可能求解以键-键值的形式存储于字典中:
#对数组中每个为0的空格列出所有可能的取值数集,并放置于字典中
def all_possible_candidate_number():
all_possible_candidate_number = {i:count_candidate_number(i) for i in range(81) if question[i] == 0}
return all_possible_candidate_number
# print(all_possible_candidate_number)
3.对每一个位置的可能求解进行判断,若可能解只有一个,则填入该解,循环直至数独求解完成
def main_count():
answer_sudoku = question
candidate_number_dic = {}
while True:
candidate_number_dic = all_possible_candidate_number() #在每次循环之前刷当前每个为0的空格,所有的取值集合
if candidate_number_dic == {}: #如果为空,则证明没有为0的空格,则为求解
answer_sudoku = question #对answer_sudoku赋值,并打印
print("已求解",answer_sudoku)
break
else:
for eachkey,eachValue in candidate_number_dic.items(): #对字典中位数为1的取值集合,既确定该数字变为当前应取值
if len(eachValue) == 1:
answer_sudoku[eachkey] = eachValue[0]
print(eachkey,eachValue[0]) #打印对应键值及对应数值
pass
if __name__ == '__main__':
main_count()
程序运行结果:
D:\pythonwokr\venv\Scripts\python.exe D:/pythonwokr/数独.py
已求解 [6, 2, 7, 5, 1, 4, 9, 8, 3, 5, 4, 8, 9, 3, 7, 2, 6, 1, 3, 9, 1, 6, 8, 2, 4, 7, 5, 4, 1, 2, 3, 7, 5, 8, 9, 6, 9, 7, 6, 1, 2, 8, 5, 3, 4, 8, 5, 3, 4, 9, 6, 7, 1, 2, 2, 6, 9, 7, 4, 1, 3, 5, 8, 1, 3, 4, 8, 5, 9, 6, 2, 7, 7, 8, 5, 2, 6, 3, 1, 4, 9]
Process finished with exit code 0
程序到这里就结束了,下一步拓展是对于若不存在单独唯一解的情况,待续。
来源:https://blog.csdn.net/wu_xying/article/details/82891913


猜你喜欢
- 本文实例讲述了Python Django中间件,中间件函数,全局异常处理操作。分享给大家供大家参考,具体如下:应用名/middleware.
- Python中的字符串方法是从python1.6到2.0慢慢加进来的,它们也被加到了Jython中。这些方法实现了string模块的大部分方
- 网页路径问题可以说是在页面设计或程序中比较典型的问题,处理得不好会给你的带来很大的麻烦,如何才能彻底解决路径问题呢!asp之家为你特别准备了
- Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文
- 前言这篇主要整理pandas常用的基本函数,主要分为五部分:汇总函数特征统计函数唯一值函数替换函数排序函数1、汇总函数常用的主要是4个:ta
- 一、语法while 条件:执行代码while就是当的意思,它指当其后面的条件成立,就执行while下面的代码。例:写一个从0打印到10的程序
- 看看怎样抓到你:<%Dim objCMFUDim strModifiedSet objCMFU 
- 大概在2004年初的时候,我第一次买了一本很厚的书,名字或许叫《Dreamweaver MX从入门到精通》,很认真看着书并实践操作大约三分之
- 在网页中放iframe,如果frameborder=0;就没有边框显示了;但动态创建时,在IE7中就不行了,从网上找到解决的办法,写出来记录
- 这个需求是有个表结构,本身设计为 但现在需要将blob里地17、18、19三个字段里的数据作为数字保存在blob外新增的三个字段Gem1 G
- 一、下载MySQL数据库并进行安装和配置下载地址:https://dev.mysql.com/downloads/installer/二、下
- 目录总体解决方案输出报表自动化Py脚本打包 EXE 桌面小程序好几个月没有写笔记了, 并非没有积累, 而是有点懒了. 想想还是要续上, 作为
- vbscript脚本中,fso对象CreateTextFile方法调用时可能会报“无效的过程调用或参数”错误,在使用ASP生成静态页面时,如
- 本文实例为大家分享了python自动发送报警监控邮件 的具体代码,供大家参考,具体内容如下因为有一些日常任务需要每日检查日否执行正确,所以需
- 一、命令格式:定义变量名称条件函数用“:”作为结尾下一级命令用空格键缩进,默认使用Tab键因为这样比较明显例如:yongHuMing = i
- 内置300余汉字点阵.纯ASP实现汉字验证码.不读数据库.多种属性自由调节,其中包括:生成的图片长和宽,字符数,背景显示效果(渐变,杂色,固
- 概要介绍mmpi,是一款使用python实现的开源邮件快速检测工具库,基于community框架设计开发。mmpi支持对邮件头、邮件正文、邮
- 一.图像加法运算1.Numpy库加法其运算方法是:目标图像 = 图像1 + 图像2,运算结果进行取模运算。当像素值<=255时,结果为
- 前言众所周知,jquery在我们日常开发中的使用频率非常高,与js相比,我们省去了冗长的获取元素的代码,不用考虑一些麻烦的兼容问题,更加方便
- 之前因为项目的原因需要使用Oracle数据库,由于时间有限没办法从基础开始学习,而且oracle操作的命令界面又太不友好,于是就找到了PL/