标签:
判断一个给出的数独模型是否符合要求。
注意点:
例子:
输入: board=[“..4…63.”,”………”,”5……9.”,”…56….”,”4.3…..1”,”…7…..”,”…5…..”,”………”,”………”]
输出: false
用三个列表表示横向、纵向和小正方形的情况。特别需要注意的是小正方形内的元素的表示方法:board[i/3*3+j/3][i%3*3+j%3]。
class Solution(object):
def isValidSudoku(self, board):
"""
:type board: List[List[str]]
:rtype: bool
"""
point = "."
for i in range(9):
row = []
column = []
square = []
for j in range(9):
element = board[i][j]
if element != point:
if element in row:
return False
else:
row.append(element)
element = board[j][i]
if element != point:
if element in column:
return False
else:
column.append(element)
element = board[i // 3 * 3 + j // 3][i % 3 * 3 + j % 3]
if element != point:
if element in square:
return False
else:
square.append(element)
return True
欢迎查看我的Github来获得相关源码。
标签:
原文地址:http://blog.csdn.net/u013291394/article/details/50450198