- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我为下面复制的 Leetcode 问题编写了以下解决方案:
Write a program to solve a Sudoku puzzle by filling the empty cells.
A sudoku solution must satisfy all of the following rules:
Each of the digits 1-9 must occur exactly once in each row. Each of the digits 1-9 must occur exactly once in each column. Each of the the digits 1-9 must occur exactly once in each of the 9 3x3 sub-boxes of the grid. Empty cells are indicated by the character '.'. Note:
The given board contain only digits 1-9 and the character '.'. You may assume that the given Sudoku puzzle will have a single unique solution. The given board size is always 9x9.
class Solution:
def solveSudoku(self, board: List[List[str]]) -> None:
"""
Do not return anything, modify board in-place instead.
"""
EMPTY_CELL = '.'
target = set(str(n) for n in range(1, 10))
def _validate():
cols = [[board[r][c] for r in range(9)] for c in range(9)]
boxes = []
for i in (0, 3, 6):
for j in (0, 3, 6):
boxes.append([board[a][b] for a in range(i, i + 3) for b in range(j, j + 3)])
valid_rows = all(set(row) == target for row in board)
valid_cols = valid_rows and all(set(col) == target for col in cols)
valid_boxes = valid_cols and all(set(box) == target for box in boxes)
return valid_boxes
def helper(r, c):
if c == len(board[0]):
return helper(r + 1, 0)
if r == len(board):
return _validate()
if not board[r][c] == EMPTY_CELL:
return helper(r, c + 1)
for n in range(1, 10):
board[r][c] = str(n)
if helper(r, c + 1):
return True
return False
helper(0, 0)
这是我的简单英语策略。对于每个空单元格,我尝试在该单元格中放置一个数字,然后在棋盘的其余部分递归。如果这没有导致有效的解决方案,我会回溯,增加数字,然后递归将该数字放在空单元格中。
我的验证函数为所有内容返回 False
,我最终得到了一个空白处有 9
的棋盘。该问题保证每个测试用例都有正确的解决方案。我已经遍历此代码数十次,但看不出问题所在。
(我知道我可以使用约束传播来加速解决方案,但当前的问题不是我的解决方案太慢 - 而是它的不正确)。
有人知道为什么吗?此外,如果问题陈述中不清楚这一点,则每个数字都应该是一个字符串。
最佳答案
如果您提供正确的解决方案,您的验证函数将返回真。您可以通过给它提供一个已解决的数独板来自己验证这一点:
solved_text = '''435269781
682571493
197834562
826195347
374682915
951743628
519326874
248957136
763418259'''
solved_board = [ list(line) for line in solved_text.split('\n') ]
有两个问题。首先,您实际上并没有搜索完整的解决方案空间。如果打印传递给 _validate()
的每个完整的棋盘,您会注意到一些奇怪的事情:整个棋盘总是按词汇顺序排列!这不是 10^81 组可能的棋盘。这可以通过简单地省略这两行代码来解决:
if not board[r][c] == EMPTY_CELL:
return helper(r, c + 1)
这些会导致问题,因为您在进行过程中改变棋盘状态作为副作用,但在回溯时不清理(放回空单元格)。您可以简单地省略这两行(以便 helper()
中的算法永远不会关心 (r,c) 词法排序中右边的内容)或通过添加代码来设置 board[r][c] = EMPTY_CELL
回溯时。
另一个问题是,因为您只在完整的板上运行验证,并且因为您的验证功能只能检查完整的板的正确性,所以您的算法在找到解决方案之前确实必须遍历所有 10^81 个可能的板。这不仅速度慢,而且非常棘手!相反,您应该重写您的验证函数,以便它可以验证部分 板。例如,如果第一行是 ['1', '1', '.', ..., '.'],它应该返回 False,但如果第一行是 ['1', '2', '.', ..., '.'] 它应该返回 True,因为到目前为止没有问题。显然,您现在还必须在每一步都调用 _validate(),而不仅仅是在电路板完成时...但这是值得的,因为否则您将花费大量时间探索显然永远不会起作用的电路板。
您需要先解决这两个问题,然后您的算法才能工作。
关于python - 填写数独板-回溯解题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55874225/
在 JConsole 的 MBeans 选项卡中查看我的应用程序的 MBean 时,有“属性”和“操作”的子菜单。如果将这些树结构展开到最大程度,然后单击其中一个操作,则右侧面板会显示三个部分:操作调
我有一个包含稀疏数据的人性化工作表: PART | FRUIT --------------- Alpha | | Apples | Pears Beta |
我有一个包含每小时数据的数据框: area date hour output H1 2018-07-01 07:00:00 150 H1
假设我有这样的 html 表: 16 3 2 13 5 10
我已经将一些原始数据导入到 R 中,如下所示: 表 1: ID Year Value 01 1999 25 01 2000 12 01 2002
我已经将一些原始数据导入到 R 中,如下所示: 表 1: ID Year Value 01 1999 25 01 2000 12 01 2002
我在以下问题中遇到了同样的问题: Forward Fill New Row to Account for Missing Dates 不同之处在于,我需要计算两个不同日期之间的小时数差异,例如 201
我想填写 pandas 数据框中缺失的值。最佳情况下,我希望分钟列的范围为每小时 0-60。不幸的是,数据生成过程没有记录任何 sub_count = 0 的行。有办法做到这一点吗?我的数据涵盖日期
基本对象问题我似乎无法全神贯注。我确定我想多了。填写 addFullName 函数的代码。该函数应该: Take one input parameter, a person object. Add a
是否可以在没有用户交互的情况下调用 html 表单提交?我知道可以通过 HttpClient 发出发布请求,但这并不能解决我的问题。 我需要以编程方式在网页上填写一些表单输入字段,然后“单击”提交按钮
Python 的新手,似乎无法找到我正在寻找的确切答案我相信有更简单的方法来填写此信息 我有 df1 和 df2 df1: FirstName LastName PhNo uniqueid df
您好,我有一个需要填写的 PDF 表单。该应用程序向用户(表单)提出问题,提交时应将答案填写到 PDF 空白处以供打印。 我熟悉 JS 和 Node(有一段时间没用过)。不使用 PHP。 我会在我常去
假设我有一个如下所示的数据框: ID DATE VALUE 1 31-01-2006 5 1 28-02-2006 5 1 31
我想做的是,在填写四个字符时指向下一个选项卡。每个字段应有 4 个字符,完成后应移至下一个输入框。 $(".inputs").keyup(function () { if (this
我有 3 个 div,每个都有几个输入字段和下一步按钮。我想编写一个 jQuery 片段,当单击下一个按钮时,它会检查以确保与按钮位于同一 div 内的所有输入字段都不为空。 我已经尝试了以下但没有成
我正在做一个刽子手项目。我已经让大部分代码正常工作了。 我无法工作的部分是“ secret 单词”有多个相同的字母。例如“hello”有 2 个“l”。 这是代码部分的代码,如果猜测正确,它将“---
拥有抽象对象的集合:Set foes; 我想要一个这样的方法: List getFoesByType(TypeEnum type); 我已经尝试过: List result = new ArrayLi
我正在尝试使用 scrapy 填写 POST 表单,以尝试预订火车票。 我以为 FormRequest 类可以做这件事,但我无法处理 javascript 表单。 Scrapy 爬虫什么都不返回。 我
我使用以下代码生成带有渐变的图像。我逐个元素访问数组。有更好的方法吗?谢谢。 import cv2 import numpy as np x = np.ndarray((256,256,3), dty
我有一个数据对应于数据库列表和差异行,以及它们的使用日期。 DB Dates USAGE ABC 03-06-2018 IN USE
我是一名优秀的程序员,十分优秀!