Xs and Os Referee

Question:

        井字游戏,有时也被称为“进攻和防守”,是一个两人玩家(X和O)轮流标志着3×3的网格的空间的连珠游戏。最先在任意一条直线(水平线,垂直线或对角线)上成功连接三个标记的一方获胜。

        但我们不去玩这个游戏。你将是这个游戏的裁判。你被赋予游戏的结果,以及你必须判断游戏是平局还是有人胜出,以及谁将会成为最后的赢家。如果X玩家获胜,返回“X”。如果O玩家获胜,返回“O”。如果比赛是平局,返回“D”。

输入:游戏结果作为字符串形式的列表(Unicode)。

输出: “X”,“O”或“D”作为字符串形式。

Code1:

def checkio(game_result: list) -> str:
    i = []
    for l in game_result:
        for j in range(3):
            i.append(l[j])
    
    if i[0] == i[1] == i[2] and i[0] != '.':
        winner = i[0]
    elif i[3] == i[4] == i[5] and i[3] != '.':
        winner = i[3]
    elif i[6] == i[7] == i[8] and i[6] != '.':
        winner = i[6]
    elif i[0] == i[3] == i[6] and i[0] != '.':
        winner = i[0]
    elif i[1] == i[4] == i[7] and i[1] != '.':
        winner = i[1]
    elif i[2] == i[5] == i[8] and i[2] != '.':
        winner = i[2]
    elif i[0] == i[4] == i[8] and i[0] != '.':
        winner = i[0]
    elif i[2] == i[4] == i[6] and i[2] != '.':
        winner = i[2]
    else:
        winner = 'D'
    return winner

Code2:(from checkio user:slickLash)
def checkio(game_result):

    patterns = [] + game_result
    size = len(game_result)

    for col in range(size):
        patterns.append(''.join([game_result[row][col] for row in range(size)]))

    patterns.append(''.join([game_result[x][x] for x in range(size)]))
    patterns.append(''.join([game_result[x][size - x - 1] for x in range(size)]))

    return 'X' if 'XXX' in patterns else 'O' if 'OOO' in patterns else 'D'
join()方法:
描述:join()方法用于将序列中的元素以指定的字符连接生成一个新的字符串。

语法:

str.join(sequence)

参数:

要连接的元素序列。

返回值:

返回通过指定字符连接序列中元素后生成的新字符串。


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值