37. 解数独

编写一个程序,通过已填充的空格来解决数独问题。
一个数独的解法需遵循如下规则:
数字 1-9 在每一行只能出现一次。
数字 1-9 在每一列只能出现一次。
数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。
空白格用 '.' 表示。



一个数独。



答案被标成红色。

Note:

  • 给定的数独序列只包含数字 1-9 和字符 '.' 。
  • 你可以假设给定的数独只有唯一解。
  • 给定数独永远是 9x9 形式的。

代码

class Solution:
    def solveSudoku(self, board):
        """
        :type board: List[List[str]]
        :rtype: void Do not return anything, modify board in-place instead.
        """
        self.sove(board)
    def sove(self,board):
        caice = self.findnone(board)
        if caice == (10,10):
            return True
        else:
            pg = self.pinggu(board,caice[0],caice[1])
            if len(pg) == 0:
                return False
            else:
                for i in pg:
                    board[caice[0]][caice[1]] = str(i)
                    if self.isok(board) == True:
                        return True
                    else:
                        if self.sove(board) == True:
                            return True
                        else:
                            board[caice[0]][caice[1]] = "."
    def isok(self,nowb):
        for i in range(0,len(nowb)):
            for j in range(0,len(nowb[i])):
                if nowb[i][j] == ".":
                    return False
        return True
    def findnone(self,nowb):
        for i in range(0,len(nowb)):
            for j in range(0,len(nowb[i])):
                # print(nowb[i][j])
                if nowb[i][j] == ".":
                    return (i,j)
        return (10,10)
    def pinggu(self,nowb,ii,jj):
        buf = {}
        for i in range(0,9):
            buf[nowb[ii][i]] = 1
            buf[nowb[i][jj]] = 1
        for c in [0,3,6]:
            # print(c)
            for k in [0,3,6]:
                if ((ii == c or (ii == (c+1)) or (ii == (c + 2)) ) and ( jj == k or (jj == (k+1)) or (jj == (k+2)))):
                    for i in range(c,3+c):
                        for j in range(k,3+k):
                            # print((i,j))
                            buf[nowb[i][j]] = 1
        res = []
        for i in range(1,10):
            if str(i) in buf:
                pass
            else:
                res.append(i)
        return res
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 由于对数据结构和算法掌握的不熟练,目前是小白入门阶段,痛下决心,要好好补一补。从大神大牛的算法学习,逐渐自己加强自...
    我是谁之自我发现阅读 3,935评论 1 2
  • LeetCode 的算法题 PHP解法记录 判断一个 9x9 的数独是否有效。只需要根据以下规则,验证已经填入的数...
    织毛衣的手阅读 4,778评论 0 2
  • 1 听金贵晟的《虹之间》,又想起了你…… 你说陪我的,而现在你人呢?...
    飒月残荷阅读 3,395评论 0 0
  • 曾经最喜欢的事情就是独自一人漫步于宁静 的黄昏。已经忘记这个爱好是什么时候养成 的了,但这种宁静和孤独渐渐成了一种...
    ForRabbits阅读 1,612评论 0 0
  • 你不知道自己飘着在天玄地黄,在宇宙洪荒 我们都睁大瞳孔迷失是从哪来?该到哪去? 没有找回记忆的我们在这世界,都是异乡人
    为非阅读 1,774评论 5 3

友情链接更多精彩内容