热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

LeetCode面试题16.04.井字游戏

面试题16.04.井字游戏设计一个算法,判断玩家是否赢了井字游戏。输入是一个NxN的数组棋盘,由字符,“X和O组成,

面试题 16.04. 井字游戏
设计一个算法,判断玩家是否赢了井字游戏。输入是一个 N x N 的数组棋盘,由字符" ",“X"和"O"组成,其中字符” "代表一个空位。

以下是井字游戏的规则:

玩家轮流将字符放入空位(" “)中。
第一个玩家总是放字符"O”,且第二个玩家总是放字符"X"。
"X"和"O"只允许放置在空位中,不允许对已放有字符的位置进行填充。
当有N个相同(且非空)的字符填充任何行、列或对角线时,游戏结束,对应该字符的玩家获胜。
当所有位置非空时,也算为游戏结束。
如果游戏结束,玩家不允许再放置字符。
如果游戏存在获胜者,就返回该游戏的获胜者使用的字符(“X"或"O”);如果游戏以平局结束,则返回 “Draw”;如果仍会有行动(游戏未结束),则返回 “Pending”。

示例 1:

输入: board = [“O X”," XO",“X O”]
输出: “X”
示例 2:

输入: board = [“OOX”,“XXO”,“OXO”]
输出: “Draw”
解释: 没有玩家获胜且不存在空位
示例 3:

输入: board = [“OOX”,“XXO”,"OX "]
输出: “Pending”
解释: 没有玩家获胜且仍存在空位
提示:

1 <&#61; board.length &#61;&#61; board[i].length <&#61; 100
输入一定遵循井字棋规则

解法1&#xff1a;
基于异或操作
如果某行有一个非X(空格或O)&#xff0c;那么rowHasNonXChar 就会是true&#xff0c;所以如果最后rowHasNonXChar是false&#xff0c;那么说明该行都是X。
对于列&#xff0c;主从对角线也同理。
注意第2个循环里面不能有continue&#xff0c;否则空格就不会被考虑了&#xff0c;那样某行有几个空格剩下全O的情况就会判O胜。

class Solution {
public:string tictactoe(vector<string>& board) {int n &#61; board.size();bool diagHasNonXChar &#61; false, diagHasNonOChar &#61; false;bool revDiagHasNonXChar &#61; false, revDiagHasNonOChar &#61;false;bool soFarFull &#61; true;for (int i &#61; 0; i < n; &#43;&#43;i) {bool rowHasNonXChar &#61; false, rowHasNonOChar &#61; false;bool colHasNonXChar &#61; false, colHasNonOChar &#61; false;for (int j &#61; 0; j < n; &#43;&#43;j) {if (soFarFull && board[i][j] &#61;&#61; &#39; &#39;) {soFarFull &#61; false;// continue; } if (!rowHasNonXChar) rowHasNonXChar |&#61; board[i][j] ^ &#39;X&#39;;if (!rowHasNonOChar) rowHasNonOChar |&#61; board[i][j] ^ &#39;O&#39;;if (!colHasNonXChar) colHasNonXChar |&#61; board[j][i] ^ &#39;X&#39;;if (!colHasNonOChar) colHasNonOChar |&#61; board[j][i] ^ &#39;O&#39;; }if (!rowHasNonXChar || !colHasNonXChar) return "X";if (!rowHasNonOChar || !colHasNonOChar) return "O";if (!diagHasNonXChar) diagHasNonXChar |&#61; board[i][i] ^ &#39;X&#39;;if (!diagHasNonOChar) diagHasNonOChar |&#61; board[i][i] ^ &#39;O&#39;;if (!revDiagHasNonXChar) revDiagHasNonXChar |&#61; board[i][n - i - 1] ^ &#39;X&#39;;if (!revDiagHasNonOChar) revDiagHasNonOChar |&#61; board[i][n - i - 1] ^ &#39;O&#39;;}if (!diagHasNonXChar || !revDiagHasNonXChar) return "X";if (!diagHasNonOChar || !revDiagHasNonOChar) return "O";if (soFarFull) return "Draw";return "Pending";}
};


推荐阅读
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 电话号码的字母组合解题思路和代码示例
    本文介绍了力扣题目《电话号码的字母组合》的解题思路和代码示例。通过使用哈希表和递归求解的方法,可以将给定的电话号码转换为对应的字母组合。详细的解题思路和代码示例可以帮助读者更好地理解和实现该题目。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • C语言注释工具及快捷键,删除C语言注释工具的实现思路
    本文介绍了C语言中注释的两种方式以及注释的作用,提供了删除C语言注释的工具实现思路,并分享了C语言中注释的快捷键操作方法。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 本文介绍了一种划分和计数油田地块的方法。根据给定的条件,通过遍历和DFS算法,将符合条件的地块标记为不符合条件的地块,并进行计数。同时,还介绍了如何判断点是否在给定范围内的方法。 ... [详细]
  • JVM 学习总结(三)——对象存活判定算法的两种实现
    本文介绍了垃圾收集器在回收堆内存前确定对象存活的两种算法:引用计数算法和可达性分析算法。引用计数算法通过计数器判定对象是否存活,虽然简单高效,但无法解决循环引用的问题;可达性分析算法通过判断对象是否可达来确定存活对象,是主流的Java虚拟机内存管理算法。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • Android JSON基础,音视频开发进阶指南目录
    Array里面的对象数据是有序的,json字符串最外层是方括号的,方括号:[]解析jsonArray代码try{json字符串最外层是 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
author-avatar
撩人的东莞博文
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有