Leetcode--Java--794. 有效的井字游戏

2023-12-02 18:58

本文主要是介绍Leetcode--Java--794. 有效的井字游戏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

用字符串数组作为井字游戏的游戏板 board。当且仅当在井字游戏过程中,玩家有可能将字符放置成游戏板所显示的状态时,才返回 true。
该游戏板是一个 3 x 3 数组,由字符 " ",“X” 和 “O” 组成。字符 " " 代表一个空位。
以下是井字游戏的规则:
第一个玩家总是放字符 “X”,且第二个玩家总是放字符 “O”。
“X” 和 “O” 只允许放置在空位中,不允许对已放有字符的位置进行填充。
当有 3 个相同(且非空)的字符填充任何行、列或对角线时,游戏结束。

样例描述

示例 1:
输入: board = ["O  ", "   ", "   "]
输出: false
解释: 第一个玩家总是放置“X”。示例 2:
输入: board = ["XOX", " X ", "   "]
输出: false
解释: 玩家应该是轮流放置的。示例 3:
输入: board = ["XXX", "   ", "OOO"]
输出: false示例 4:
输入: board = ["XOX", "O O", "XOX"]
输出: true

思路

模拟 + 分类讨论

  1. 某时刻x的数量要么和o相等,要么大于o
  2. 同时要记录x有没有赢,o有没有赢,不可能同时赢。
  3. 判断x赢后,x的个数一定比o多一吗,因为最后一步是x。反过来,如果是o赢了,那么x和o的个数一定相等。
    在这里插入图片描述
  4. 先写统计字符个数的函数,然后依次判断第i行,i列,对角线以及反对角线
  5. 分类四种不可能情况,双赢,x赢但多的个数大于1,o赢但个数不等于x,没人赢但棋局出现x个数比o大的多1,或者x不等于0。

代码

class Solution {String[] board;public int get(char c) {int res = 0;for (int i = 0; i < board.length; i ++ ) {for (int j = 0; j < board[i].length(); j ++ ) {if (c == board[i].charAt(j)) {res ++;}}}return res;}//判断局面,也就是是否存在某行某列某对角等于cpublic boolean check(char c) {//先判断行和列for (int i = 0; i < 3; i ++ ) {if (board[i].charAt(0) == c && board[i].charAt(1) == c && board[i].charAt(2) == c) return true;if (board[0].charAt(i) == c && board[1].charAt(i) == c && board[2].charAt(i) == c) return true;}//正、反对角线if (board[0].charAt(0) == c && board[1].charAt(1) == c && board[2].charAt(2) == c) return true;if (board[0].charAt(2) == c && board[1].charAt(1) == c && board[2].charAt(0) == c) return true;return false;}public boolean validTicTacToe(String[] _board) {board = _board;int cntX = get('X'), cntO = get('O');boolean bX = check('X'), bO = check('O');//同时赢,显然不可能if (bX && bO) return false;//x赢,如果不是恰好多一个if (bX && cntX != cntO + 1) return false;//o赢,如果不是恰好等于xif (bO && cntO != cntX) return false;//如果数量不是X等于O或者x比O多一,那就不可能if (!(cntO == cntX || cntX == cntO + 1)) return false;return true; }
}

这篇关于Leetcode--Java--794. 有效的井字游戏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/446430

相关文章

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

Java中Integer128陷阱

《Java中Integer128陷阱》本文主要介绍了Java中Integer与int的区别及装箱拆箱机制,重点指出-128至127范围内的Integer值会复用缓存对象,导致==比较结果为true,下... 目录一、Integer和int的联系1.1 Integer和int的区别1.2 Integer和in

SpringSecurity整合redission序列化问题小结(最新整理)

《SpringSecurity整合redission序列化问题小结(最新整理)》文章详解SpringSecurity整合Redisson时的序列化问题,指出需排除官方Jackson依赖,通过自定义反序... 目录1. 前言2. Redission配置2.1 RedissonProperties2.2 Red

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap