python37降到36原来的包还可以用吗_【lc刷题】36/37 有效的数独/解数独(143-144/300)...

143-144/300

有效的数独

判断一个 9x9 的数独是否有效。只需要根据以下规则,验证已经填入的数字是否有效即可。

数字 1-9 在每一行只能出现一次。

数字 1-9 在每一列只能出现一次。

数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。

上图是一个部分填充的有效的数独。

数独部分空格内已填入了数字,空白格用 ‘.’ 表示。

示例 1:

输入:

[

[“5”,“3”,".",".",“7”,".",".",".","."],

[“6”,".",".",“1”,“9”,“5”,".",".","."],

[".",“9”,“8”,".",".",".",".",“6”,"."],

[“8”,".",".",".",“6”,".",".",".",“3”],

[“4”,".",".",“8”,".",“3”,".",".",“1”],

[“7”,".",".",".",“2”,".",".",".",“6”],

[".",“6”,".",".",".",".",“2”,“8”,"."],

[".",".",".",“4”,“1”,“9”,".",".",“5”],

[".",".",".",".",“8”,".",".",“7”,“9”]

]

输出: true

示例 2:

输入:

[

[“8”,“3”,".",".",“7”,".",".",".","."],

[“6”,".",".",“1”,“9”,“5”,".",".","."],

[".",“9”,“8”,".",".",".",".",“6”,"."],

[“8”,".",".",".",“6”,".",".",".",“3”],

[“4”,".",".",“8”,".",“3”,".",".",“1”],

[“7”,".",".",".",“2”,".",".",".",“6”],

[".",“6”,".",".",".",".",“2”,“8”,"."],

[".",".",".",“4”,“1”,“9”,".",".",“5”],

[".",".",".",".",“8”,".",".",“7”,“9”]

]

输出: false

解释: 除了第一行的第一个数字从 5 改为 8 以外,空格内其他数字均与 示例1 相同。

但由于位于左上角的 3x3 宫内有两个 8 存在, 因此这个数独是无效的。

说明:

一个有效的数独(部分已被填充)不一定是可解的。

只需要根据以上规则,验证已经填入的数字是否有效即可。

给定数独序列只包含数字 1-9 和字符 ‘.’ 。

给定数独永远是 9x9 形式的。

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/valid-sudoku

思路:记录

根据题目要求,对于每一个数,都有三个点位:某行,某列,某个3x3 subgrid

只要保证不重复就ok。 譬如下图:左边图是个美好的数独,右边图改了一下。

对于[0][0]的’8’有三个点位:0行,0列,(0,0)的subgrid

对于[2][2]的’8’有三个点位:2行,2列,(0,0)的subgrid

对于[3][0]的’8’有三个点位:3行,0列,(1,1)的subgrid

这就说明(0,0)subgrid有俩’8’,0列也有俩’8’,不行啊。

所以见过的用(行,此数字),(此数字,列)【倒个个儿,防止行列不分】,(subgrid的坐标,此数字) 来记录。

然后判断集合==set(此集合),同则T,不同就F。

class Solution:

def isValidSudoku(self, board: List[List[str]]) -> bool:

res = []

for i, row in enumerate(board):

for j, n in enumerate(row):

if n != '.':

res += (i,n),(n,j),(i//3,j//3,n)

return len(res) == len(set(res))1

2

3

4

5

6

7

8

9

10

解数独

编写一个程序,通过已填充的空格来解决数独问题。

一个数独的解法需遵循如下规则:

数字 1-9 在每一行只能出现一次。

数字 1-9 在每一列只能出现一次。

数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。

空白格用 ‘.’ 表示。

一个数独。

答案被标成红色。

Note:

给定的数独序列只包含数字 1-9 和字符 ‘.’ 。

你可以假设给定的数独只有唯一解。

给定数独永远是 9x9 形式的。

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/sudoku-solver

思路:有选择的尝试

譬如走到[0][2]要填个数:

最初选择:{‘1’, ‘2’, ‘3’, ‘4’, ‘5’, ‘6’, ‘7’, ‘8’, ‘9’}

减去行出现过的{’.’, ‘3’, ‘5’, ‘7’}

减去列出现过的 {’.’, ‘8’}

减去subgrid中出现过的:{’.’, ‘3’, ‘5’, ‘6’, ‘8’, ‘9’}

最后的结果是:{‘1’, ‘2’, ‘4’}

然后当[0][2]=1时,走向[0][3],开始新的一轮尝试。

譬如,前面都尝试没问题,然后尝试[0][7] =2的下一步[0][8] = 9

但列出现过9,这时候{‘1’, ‘2’, ‘3’, ‘4’, ‘5’, ‘6’, ‘7’, ‘8’, ‘9’} - {‘1’, ‘2’, ‘3’, ‘4’, ‘5’, ‘6’, ‘7’, ‘8’}-{‘1’, ‘3’, ‘5’, ‘6’, ‘9’} - {‘1’, ‘2’, ‘6’} = set(), 屁也没有, 退回上一步[0][7] =2, 把[0][7]恢复为’.’

然后尝试[0][7] =9,那么下一步[0][8] = 2

行列subgrid都不重复,进入下一行的尝试,[1][1] = …

当进行到[8][2] =1时,一切完美,没有’.'的存在,我们就可以一层层返回之前的尝试收尾。

class Solution:

def solveSudoku(self, board):

def dfs():

for i, row in enumerate(board):

for j, num in enumerate(row):

if num == '.':

for x in {'1', '2', '3', '4', '5', '6', '7', '8', '9'} - {row[k] for k in range(9)} - {board[k][j] for k in range(9)} - {board[i // 3 * 3 + m][j // 3 * 3 + n] for m in range(3) for n in range(3)}:

board[i][j] = x

if dfs(): return True

board[i][j] = '.'

return False

return True

dfs()1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部