验证数独的函数中存在问题
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 falseif board[x][i] == board[x][y] and i != y: return false # 错误验证 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 and k – 8 != x: return false return true
问题出在这个错误的验证中:
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 and k – 8 != x: return false
这段代码尝试验证对角线元素,但它违背了问题要求:
条件中不应该检查对角线元素。函数 verify_line 的目的是检查行和列中的值。k – 8 != x 条件不正确。它在检查对角线元素时没有必要。
以下是如何更正该函数:
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 Falseif board[x][i] == board[x][y] and i != y: return False return True
以上就是数独验证函数中的错误:为什么验证对角线元素是错误的?的详细内容,更多请关注范的资源库其它相关文章!
转载请注明:范的资源库 » 数独验证函数中的错误:为什么验证对角线元素是错误的?