【二维数组】判断井字棋玩家是否获胜

该博客介绍如何使用二维数组判断井字棋游戏中玩家是否获胜。根据棋盘上1的分布,检查行、列及对角线,若存在连成排的1,即表示当前玩家获胜。博客提供了一种解决方案,强调了在计算过程中需要注意清除上一次计算的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

给定一个二维数组board,代表棋盘,其中元素为1的代表是当前玩家的棋子,0表示没有棋子,-1代表是对方玩家的棋子。当一方棋子在横竖斜方向上有连成排的及获胜(及井字棋规则),返回当前玩家是否胜出。

测试样例:

[[1,0,1],[1,-1,-1],[1,-1,0]]

返回:true

题目分析

井字棋游戏规则,就是判断行、列以及对角线上的棋子是否全部相同

根据给定的二维数组,由于井字棋行和列相等,并且当前玩家的棋子为1, 只需计算某一行或者某一列的和为二维数组的行数,再判断两条对角线的和,如果有一个条件满足即玩家获胜。

在计算时,要注意每次统计每一行每一列,对角线的和时注意将sum置0,不然会被上次的计算结果干扰导致程序出错。

代码如下:

import java.util.*;

public class Board {
    public boolean checkWon(int[][] board) {//这里首先判断此二维数组的两斜边是否被玩家相连
        if(board[0][0] + board[1][1] + board[2][2] == 3 || board[0][2] + board[1][1] + board[2][0] == 3) {
            return true;
        }
        for(int i = 0; i < 3 ;i++) {//这里用一个循环判断每一行每一列是否被玩家相连
            if(board[i][0] + board[i][1] + board[i][2] == 3 || board[0][i] + board[1][i] + board[2][i
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值