
初级算法题遇到的问题 求大佬帮忙看一下哪里出问题了
问题描述:
作者在使用 verify_line 函数检查数独方格的行和列时,遇到条件为 false 但仍然进入 if 的问题。作者怀疑问题可能是 verify_line 函数中的判断条件存在问题。
原因分析:
从给出的代码来看,verify_line 函数中除了检查行和列之外,还包含了对角线方向的验证,但是题目中并没有要求验证对角线。因此,当对角线方向上的元素与当前元素相同时,函数会判断为 true,导致条件为 false 时也会进入 if。
解决方法:
只需删除与对角线验证相关的代码即可:
- if x == y or x + y == 8: - for k in range(9): - if board[k][k] == board[x][y] and k != x: - return false - if board[k][8 - k] == board[x][y] and k != x: - return false
删除后,verify_line 函数将只判断行和列方向。
修复后的代码:
class Solution(object):
def verify_line(self, board, x, y):
for i in range(9):
if board[i][y] == board[x][y] and i != x:
return False
if board[x][i] == board[x][y] and i != y:
return False
return True
def verify_sudoku(self, board, x, y):
for p in range(3):
for q in range(3):
if board[x][y] == board[x + p - x % 3][y + q - y % 3]:
if p - x % 3 == 0 and q - y % 3 == 0:
continue
return False
return True
def isValidSudoku(self, board):
"""
:type board: List[List[str]]
:rtype: bool
"""
for u in range(9):
for o in range(9):
if board[u][o] != ".":
if not (self.verify_line(board, u, o) and self.verify_sudoku(board, u, o)):
return False
return True以上就是数独验证代码问题:为什么条件为 False 仍然进入 if 语句?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号