PHP前端开发

数独验证算法中,添加对角线验证导致条件为 False 时仍进入 if 的原因是什么?

百变鹏仔 2个月前 (01-14) #Python
文章标签 对角线

初级算法题遇到的问题 求大佬帮忙看一下哪里出问题了

问题:
验证数独的算法中,在一个 if 语句中添加了对角线验证,导致条件为 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

解决方案:

这个问题是由多余的对角线验证引起的。在检查行列时,不需要单独验证对角线,因为对角线元素的行和列也会被其他验证逻辑覆盖。

因此,可以删除对角线验证部分。修改后的代码如下:

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