python实现解数独程序的代码示例

最近在带孩子学习数独,职业使然,就上网搜了下相关程序的解法,这里分享给大家,希望对大家学习python有所帮助

偶然发现linux系统附带的一个数独游戏,打开玩了几把。无奈是个数独菜鸟,以前没玩过,根本就走不出几步就一团浆糊了。

于是就打算借助计算机的强大运算力来暴力解数独,还是很有乐趣的。

下面就记录一下我写解数独程序的一些思路和心得。

一.数独游戏的基本解决方法

立即学习“Python免费学习笔记(深入)”;

编程笼统的来说,就是个方法论。不论什么程序,都必须将问题的解决过程分解成计算机可以实现的若干个简单方法。俗话说,大道至简。对于只能明白0和1的计算机来说,就更需要细分步骤,一步一步的解决问题了。

首先来思考一下解数独的基本概念。

数独横九竖九共八十一个格子,同时又分为9个九宫格。规则很简单——需要每一个格中的数字,都保证与其所在横排和竖排以及九宫格内无相同数字。

所以我们的大概思路就是,从第一个空格开始试着填数,从 1 开始填,如果 1 不满足横排竖排九宫格无重复的话,就再填入 2 ,以此类推,直到填入一个暂时满足规则的数,中断此格,移动到下一个空格重复这个过程。

如果到达某个空格发现已经无数可选了,说明前面某一格填错了,那就返回上一格,从上一格的中断处继续往 9 尝试,直到这样回朔到填错的那一格。

这样的话,我们就可以整理出重要的步骤了:

•寻找到下一个空格
•轮流填入格中数字 1 到 9
•递归判断填入数是否符合规则

二.程序

首先测试数独使用的是芬兰数学家因卡拉花费3个月时间设计出的世界上迄今难度最大的数独。如下

python实现解数独程序的代码示例

将空格用 0 表示,同时将数独表示成嵌套的列表,这样每格的行数和列数就正好是列表中每个对应数的索引。

程序如下:

 #coding=utf-8 import datetime class solution(object):   def __init__(self,board):     self.b = board     self.t = 0    def check(self,x,y,value):#检查每行每列及每宫是否有相同项     for row_item in self.b[x]:       if row_item == value:         return False     for row_all in self.b:       if row_all[y] == value:         return False     row,col=x/3*3,y/3*3     row3col3=self.b[row][col:col+3]+self.b[row+1][col:col+3]+self.b[row+2][col:col+3]     for row3col3_item in row3col3:       if row3col3_item == value:         return False     return True    def get_next(self,x,y):#得到下一个未填项     for next_soulu in range(y+1,9):       if self.b[x][next_soulu] == 0:         return x,next_soulu     for row_n in range(x+1,9):       for col_n in range(0,9):         if self.b[row_n][col_n] == 0:           return row_n,col_n     return -1,-1 #若无下一个未填项,返回-1    def try_it(self,x,y):#主循环     if self.b[x][y] == 0:       for i in range(1,10):#从1到9尝试         self.t+=1         if self.check(x,y,i):#符合 行列宫均无条件 的           self.b[x][y]=i #将符合条件的填入0格           next_x,next_y=self.get_next(x,y)#得到下一个0格           if next_x == -1: #如果无下一个0格             return True #返回True           else:    #如果有下一个0格,递归判断下一个0格直到填满数独             end=self.try_it(next_x,next_y)             if not end:  #在递归过程中存在不符合条件的,即 使try_it函数返回None的项               self.b[x][y] = 0  #回朔到上一层继续             else:               return True    def start(self):     begin = datetime.datetime.now()     if self.b[0][0] == 0:       self.try_it(0,0)     else:       x,y=self.get_next(0,0)       self.try_it(x,y)     for i in self.b:       print i     end = datetime.datetime.now()     print 'cost time:', end - begin     print 'times:',self.t     return   s=solution([[8,0,0,0,0,0,0,0,0],     [0,0,3,6,0,0,0,0,0],     [0,7,0,0,9,0,2,0,0],     [0,5,0,0,0,7,0,0,0],     [0,0,0,8,4,5,7,0,0],     [0,0,0,1,0,0,0,3,0],     [0,0,1,0,0,0,0,6,8],     [0,0,8,5,0,0,0,1,0],     [0,9,0,0,0,0,4,0,0]]) 73 s.start()

登录后复制

值得注意的是使用的递归判断能够很巧妙的在走错分支时回朔到上一层。具体实现是通过 for 循环来从 1 到 9 不断填入数字同时达到记录中断点的作用。通过下一层的返回值来确定是否回朔。

程序输出如下:

[8, 1, 2, 7, 5, 3, 6, 4, 9][9, 4, 3, 6, 8, 2, 1, 7, 5][6, 7, 5, 4, 9, 1, 2, 8, 3][1, 5, 4, 2, 3, 7, 8, 9, 6][3, 6, 9, 8, 4, 5, 7, 2, 1][2, 8, 7, 1, 6, 9, 5, 3, 4][5, 2, 1, 9, 7, 4, 3, 6, 8][4, 3, 8, 5, 2, 6, 9, 1, 7][7, 9, 6, 3, 1, 8, 4, 5, 2]cost time: 0:00:00.060687times: 45360

登录后复制

可以看到程序虽然运算次数比较多,但是速度还是很快的。

以上就是python实现解数独程序的代码示例的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2273756.html

(0)
上一篇 2025年2月27日 13:34:13
下一篇 2025年2月27日 13:35:02

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • DeepSeek如何本地部署-探索DeepSeek本地部署全面指南

    deepseek本地部署指南:高效运行深度学习模型 DeepSeek是一款强大的本地部署深度学习工具,专为AI开发者打造。本文将指导您完成DeepSeek的本地部署,并提供一些实用技巧,助您快速上手。 DeepSeek本地部署步骤 首先,请…

    2025年3月29日
    100
  • deepseek怎么用python调用

    在开始之前,请确保你的计算机上已安装python和pip。打开命令提示符(windows)或终端(mac/linux),输入以下命令来验证python和pip的安装情况: “` python –version pip…

    2025年3月29日
    100
  • 普通人怎样高效利用DeepSeek-DeepSeek使用技巧助普通人一臂之力

    在当今信息爆炸的时代,高效地获取和处理数据成为了我们日常生活和工作中不可或缺的技能。deepseek作为一款强大的数据搜索与分析工具,为普通人提供了一个便捷的途径来挖掘隐藏在海量数据中的宝贵信息。接下来,我们将详细介绍普通人如何用好deep…

    2025年3月29日
    100
  • 一键搭建DeepSeek-详尽指南教你如何本地部署DeepSeek

    本文将指导您如何在本地环境快速部署deepseek,无需繁琐配置。只需几步,即可轻松运行deepseek。 准备工作: 确保您的系统符合DeepSeek的最低运行要求,并已安装所有必要依赖项。 下载脚本: 从官方GitHub仓库获取最新的一…

    2025年3月29日
    100
  • deepseek怎么编程

    DeepSeek并非编程语言,而是深度搜索概念。实现DeepSeek需基于现有语言选择。针对不同应用场景,需要选择合适的语言和算法,并结合机器学习技术。代码质量、可维护性、测试至关重要。根据需求选择合适的编程语言、算法和工具,并编写高质量代…

    2025年3月29日
    100
  • 怎么下载deepseek 小米

    如何下载 DeepSeek 小米?在小米应用商店搜索“DeepSeek”,如未找到,则继续步骤 2。确定您的需求(搜索文件、数据分析),并找到包含 DeepSeek 功能的相应工具(如文件管理器、数据分析软件)。 怎么下载DeepSeek小…

    2025年3月29日
    100
  • deepseek该怎么搜索

    直接使用DeepSeek自带的搜索功能即可,它强大的语义分析算法能准确理解搜索意图,提供相关信息。但对于冷门领域、最新信息或需要思考问题的搜索,需要调整关键词或使用更具体的描述、结合其他实时信息来源,并明白DeepSeek只是一个工具,需要…

    2025年3月29日
    100
  • deepseek怎么问他

    有效使用DeepSeek的关键在于清晰提问:直接、具体地表达问题。提供具体细节和背景信息。对于复杂的询问,包含多个角度和反驳观点。关注特定方面,例如代码的性能瓶颈。对得到的答案保持批判性思维,结合专业知识进行判断。 DeepSeek怎么问它…

    2025年3月29日
    100
  • DeepSeek本地部署如何操作-DeepSeek本地安装步骤指南

    deepseek本地部署详解:快速搭建专属数据搜索平台 DeepSeek是一款功能强大的数据搜索与分析工具,本文将指导您完成DeepSeek的本地部署,构建高效的信息检索平台。 准备工作: 系统要求: 请确保您的服务器或电脑满足DeepSe…

    2025年3月29日
    100
  • deepseek怎么用来算账

    问题:DeepSeek是否可用于会计?回答:不是,它是一个数据挖掘和分析工具,可用于分析财务数据,但本身不具备会计软件的账目记录和报表生成功能。使用DeepSeek分析财务数据需要:编写代码来处理数据具备对数据结构、算法和DeepSeek …

    2025年3月29日
    100

发表回复

登录后才能评论