python数独唯一解,数独唯一解法

本文目录一览:

数独人造解法的一些技巧及其python实现怎么解决

总共有十几种解题技巧,其中最直接的是显式唯一数法和隐式唯一数法。所谓显式唯一数法,是指某个格只有一个候选数可选,这个格自然就只能填这个候选数了。

而隐式唯一数法的意思则是,某一行、列或宫只有一个位置可以填某个候选数,当然,这个位置肯定就填这个候选数了。

怎么用python解数独的算法题,给个矩阵里面填充了若干数,用程序自动给填充完整

class Solution:

    # @param board, a 9×9 2D array

    # Solve the Sudoku by modifying the input board in-place.

    # Do not return any value.

    def solveSudoku(self, board):

        self.board = board

        self.solve()

    

    def findUnassigned(self):

        for row in range(9):

            for col in range(9):

                if self.board[row][col] == “.”:

                    return row, col

        return -1, -1

    

    def solve(self):

        row, col = self.findUnassigned()

        #no unassigned position is found, puzzle solved

        if row == -1 and col == -1:

            return True

        for num in [“1″,”2″,”3″,”4″,”5″,”6″,”7″,”8″,”9”]:

            if self.isSafe(row, col, num):

                self.board[row][col] = num

                if self.solve():

                    return True

                self.board[row][col] = “.”

        return False

                

    def isSafe(self, row, col, ch):

        boxrow = row – row%3

        boxcol = col – col%3

        if self.checkrow(row,ch) and self.checkcol(col,ch) and self.checksquare(boxrow, boxcol, ch):

            return True

        return False

    

    def checkrow(self, row, ch):

        for col in range(9):

            if self.board[row][col] == ch:

                return False

        return True

    

    def checkcol(self, col, ch):

        for row in range(9):

            if self.board[row][col] == ch:

                return False

        return True

       

    def checksquare(self, row, col, ch):

        for r in range(row, row+3):

            for c in range(col, col+3):

                if self.board[r][c] == ch:

                    return False

        return True

用Python判断数独是否正确

#coding=utf-8

num_list=[

[5, 3, 4, 6, 7, 8, 9, 1, 2],

[6, 7, 2, 1, 9, 5, 3, 4, 8],

[1, 9, 8, 3, 4, 2, 5, 6, 7],

[8, 5, 9, 7, 6, 1, 4, 2, 3],

[4, 2, 6, 8, 5, 3, 7, 9, 1],

[7, 1, 3, 9, 2, 4, 8, 5, 6],

[9, 6, 1, 5, 3, 7, 2, 8, 4],

[2, 8, 7, 4, 1, 9, 6, 3, 5],

[3, 4, 5, 2, 8, 6, 1, 7, 9]

]

tmp = [1,2,3,4,5,6,7,8,9]

def check_shudu(num_list):

    #

    if len(num_list)9:

        return -1

    #

    for j in num_list:

        if sorted(j)tmp:

            return -1

    #

    for i in range(9):

        if sorted([j[i] for j in num_list])tmp:

            return -1

    #

    for n in range(3):

        for k in range(3):

            jiu = []

            for i in range(n*3,n*3+3):

                for j in range(k*3,k*3+3):

                    jiu.append(num_list[i][j])

            if sorted(jiu)tmp:

                return -1

    return 1

print check_shudu(num_list)

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/242790.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-12 12:52
下一篇 2024-12-12 12:52

相关推荐

  • Python计算阳历日期对应周几

    本文介绍如何通过Python计算任意阳历日期对应周几。 一、获取日期 获取日期可以通过Python内置的模块datetime实现,示例代码如下: from datetime imp…

    编程 2025-04-29
  • Python列表中负数的个数

    Python列表是一个有序的集合,可以存储多个不同类型的元素。而负数是指小于0的整数。在Python列表中,我们想要找到负数的个数,可以通过以下几个方面进行实现。 一、使用循环遍历…

    编程 2025-04-29
  • Python周杰伦代码用法介绍

    本文将从多个方面对Python周杰伦代码进行详细的阐述。 一、代码介绍 from urllib.request import urlopen from bs4 import Bea…

    编程 2025-04-29
  • 如何查看Anaconda中Python路径

    对Anaconda中Python路径即conda环境的查看进行详细的阐述。 一、使用命令行查看 1、在Windows系统中,可以使用命令提示符(cmd)或者Anaconda Pro…

    编程 2025-04-29
  • Python中引入上一级目录中函数

    Python中经常需要调用其他文件夹中的模块或函数,其中一个常见的操作是引入上一级目录中的函数。在此,我们将从多个角度详细解释如何在Python中引入上一级目录的函数。 一、加入环…

    编程 2025-04-29
  • python强行终止程序快捷键

    本文将从多个方面对python强行终止程序快捷键进行详细阐述,并提供相应代码示例。 一、Ctrl+C快捷键 Ctrl+C快捷键是在终端中经常用来强行终止运行的程序。当你在终端中运行…

    编程 2025-04-29
  • Python清华镜像下载

    Python清华镜像是一个高质量的Python开发资源镜像站,提供了Python及其相关的开发工具、框架和文档的下载服务。本文将从以下几个方面对Python清华镜像下载进行详细的阐…

    编程 2025-04-29
  • Python程序需要编译才能执行

    Python 被广泛应用于数据分析、人工智能、科学计算等领域,它的灵活性和简单易学的性质使得越来越多的人喜欢使用 Python 进行编程。然而,在 Python 中程序执行的方式不…

    编程 2025-04-29
  • 蝴蝶优化算法Python版

    蝴蝶优化算法是一种基于仿生学的优化算法,模仿自然界中的蝴蝶进行搜索。它可以应用于多个领域的优化问题,包括数学优化、工程问题、机器学习等。本文将从多个方面对蝴蝶优化算法Python版…

    编程 2025-04-29
  • Python字典去重复工具

    使用Python语言编写字典去重复工具,可帮助用户快速去重复。 一、字典去重复工具的需求 在使用Python编写程序时,我们经常需要处理数据文件,其中包含了大量的重复数据。为了方便…

    编程 2025-04-29

发表回复

登录后才能评论