数独验证代码问题:为什么条件为 False 仍然进入 if 语句?

ID:20794 / 打印

数独验证代码问题:为什么条件为 false 仍然进入 if 语句?

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

问题描述:

作者在使用 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
上一篇: 如何避免 Python 线程池爬虫中的数据紊乱问题?
下一篇: 推荐库

作者:admin @ 24资源网   2025-01-14

本站所有软件、源码、文章均有网友提供,如有侵权联系308410122@qq.com

与本文相关文章

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。