LeetCode1275.找出井字棋的获胜者

题目链接:

1275. 找出井字棋的获胜者 - 力扣(LeetCode)

分析:这个题也属于普通的模拟题,说实话感觉自己做的比较笨拙,就是老实模拟下棋的过程,仅供大家参考,热烈欢迎有大佬能给点拨一下更好的思路。

算法思路:先对下棋的序列进行一个基本的判断,如果少于5步,那说明游戏一定还需要继续。这是第一种边界情况,大家一定要考虑。

接下来开辟一个3*3的数组v,表示井字棋的棋盘,我们遍历整个题目给出的数组来模拟下棋的过程,因为是A B轮换下棋,所以我们可以通过下棋时的奇偶来判断这一步该由谁来下。按顺序模拟结束整个下棋过程即可。为了方便理解,我们不使用题目中的X、O,反而使用1,-1来分别代表A、B的下棋结果,这样也方便对后续的统计。

接下来需要整理棋盘,判断是否由获胜者,这里用了不高明的办法--挨个计算。定义了八个int值,表明所有可能出现的结果,然后依次进行计算(这一部分在代码给出了)。计算结束后,如果结果中出现了3,说明A胜出了;如果出现了-3说明B胜出了。如果都没有,那么我们需要进一步判断一共走了多少步,如果已经9步,说明已经无路可走,返回平局,否则返回游戏尚未结束。

这个过程稍微有点抽象,希望大家细心理解。

下面是参考代码:

cpp 复制代码
class Solution {
public:
    string tictactoe(vector<vector<int>>& moves) {
        if(moves.size()<=4)//如果一共没有走过4步 说明游戏一定没有结束 直接返回Pending
            return "Pending";
        vector<vector<int>>v(3,vector<int>(3,0));//定义一个3*3的数组模拟井字棋棋盘
        for(int i=0;i<moves.size();++i){//遍历下棋的所有步骤
            if(i%2==0){//A下棋
                v[moves[i][0]][moves[i][1]]=1;//A下的棋落到了这个位置
            }else{//B下棋
                v[moves[i][0]][moves[i][1]]=-1;//B的棋落到了这个位置
            }
        }
        //用8个字母代表了所有可能的和
        int a=v[0][0]+v[0][1]+v[0][2];//第一行的和
        int b=v[1][0]+v[1][1]+v[1][2];//第二行的和
        int c=v[2][0]+v[2][1]+v[2][2];//第三行的和
        int d=v[0][0]+v[1][0]+v[2][0];//第一列的和
        int e=v[0][1]+v[1][1]+v[2][1];//第二列的和
        int f=v[0][2]+v[1][2]+v[2][2];//第三列的和
        int g=v[0][0]+v[1][1]+v[2][2];//主对角线的和
        int h=v[0][2]+v[1][1]+v[2][0];//副对角线的和
        if(a==3||b==3||c==3||d==3||e==3||f==3||g==3||h==3)//A获胜的情况一定在这其中
            return "A";
        if(a==-3||b==-3||c==-3||d==-3||e==-3||f==-3||g==3||h==-3)//B获胜的情况一定在这其中
            return "B";
        if(moves.size()==9)//若两人都没有获胜且走了9步 那么就是平局
            return "Draw";
        return "Pending";//否则游戏仍然没有结束
    }
};
相关推荐
TracyCoder1235 分钟前
LeetCode Hot100(28/100)——104. 二叉树的最大深度
算法·leetcode
执着25915 分钟前
力扣hot100 - 101、对称二叉树
数据结构·算法·leetcode
多恩Stone17 分钟前
【3D-AICG 系列-1】Trellis v1 和 Trellis v2 的区别和改进
人工智能·pytorch·python·算法·3d·aigc
数智工坊20 分钟前
【数据结构-栈、队列、数组】3.3栈在括号匹配-表达式求值上
java·开发语言·数据结构
mit6.82423 分钟前
模运算|z函数 字符串匹配
算法
阿豪只会阿巴25 分钟前
【吃饭香系列】二周目|代码随想录算法训练营第七天|454.四数相加II |383. 赎金信 |15. 三数之和 |18. 四数之和
算法
小O的算法实验室28 分钟前
2025年COR SCI2区,考虑风场影响的无人机搜救覆盖路径规划精确界算法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
xqqxqxxq30 分钟前
洛谷算法1-3 暴力枚举(NOIP经典真题解析)java(持续更新)
java·开发语言·算法
_OP_CHEN31 分钟前
【算法基础篇】(五十五)卡特兰数封神之路:从括号匹配到二叉树构造,组合数学的万能钥匙!
算法·蓝桥杯·c/c++·组合数学·卡特兰数·算法竞赛·acm/icpc
郝学胜-神的一滴34 分钟前
Python美学的三重奏:深入浅出列表、字典与生成器推导式
开发语言·网络·数据结构·windows·python·程序人生·算法