leetcode 36. 有效的数独
这道题一开始是想要采用哈希表的方式来做,但是对于哈希表还不是很熟系,对于python中的两层的for循环也没有很了解,还是欠缺了很多的地方 class Solution: def isValidSudoku(self, board: List[List[str]]) -> bool: row = [[x for x in y if x!='.'] for y in board] col = [[x for x in y if x!='.'] for y in zip(*board)] pal = [[board[i+m][j+n] for m in range(3) for n in range (3) if board[i+m][j+n]!='.'] for i in (0,3,6) for j in (0,3,6)] return all(len(set(x)) == len(x) for x in (*row, *col, *pal)) 前三行代码很好理解,就是对于行,列,9个方格中的数字进行插入 row:就是按行遍历,把除了' .'以外的数字放入到row中 col:中的zip处理的是元祖,也可以理解为按照列来处理,并且有一个* 是处理成list类型 zip() 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的对象