原题地址
本文只总结基本函数用法, 有题目答案但不进行过多分析.
问题大意:
N
子棋,只要自己的棋子在行,列或者对角线方向上有连续相同的N
个,就算获胜. 由于限定了棋盘大小为N
,因此对角线方向只存在两种可能:
因此只需监测是否存在满足要求的 行或者 列 以及上面两种情况.
代码:
n = len(board)
def check(c):
target = c * n
# any()只接收一个参数,所以需要将四部分括起来
return any(
(any(row == target for row in board), # 判断行
any(col == target for col in map(''.join, zip(*board))), # 判断列
all(board[i][i] == c for i in range(n)), # 判断对角1
all(board[i][n-1-i] == c for i in range(n))) # 判断对角2
)
if check('X'):
return "X"
if check("O"):
return "O"
if ' ' in ''.join(board): # 还有空,没下完
return "Pending"
return "Draw" # 平局
基本函数整理
No.1 Function: any()
any 函数用于判断给定的可迭代参数 iterable 是否全部为 False,则返回 False,如果有一个为 True,则返回 True.
菜鸟教程
No.2 Function: all()
all 函数用于判断给定的可迭代参数iterable
中的所有元素是否都为TRUE
,如果是返回True
,否则返回False
。
元素除了是0
、空、None
、False
外都算 True
。
No.3 Function: zip()
zip 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表。
如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用*
号操作符,可以将元组解压为列表。
菜鸟教程
所谓的解压这里可以理解为利用*
以列
为单位进行数据提取,将原数组中的元素,作为iterable
对象分别传入zip
.