井字游戏 on LeetCode

原题地址

本文只总结基本函数用法, 有题目答案但不进行过多分析.


问题大意:

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、空、NoneFalse外都算 True

No.3 Function: zip()
zip 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表。
如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用*号操作符,可以将元组解压为列表。
菜鸟教程
所谓的解压这里可以理解为利用*为单位进行数据提取,将原数组中的元素,作为iterable对象分别传入zip.
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值