当前位置: 首页 > news >正文

leetcode810. 黑板异或游戏(博弈论 - java)

黑板异或游戏

  • lc 810 - 黑板异或游戏
    • 题目描述
    • 博弈论
  • 动态规划

lc 810 - 黑板异或游戏

难度 - 困难
原题链接 - 黑板异或游戏

题目描述

黑板上写着一个非负整数数组 nums[i] 。
Alice 和 Bob 轮流从黑板上擦掉一个数字,Alice 先手。如果擦除一个数字后,剩余的所有数字按位异或运算得出的结果等于 0 的话,当前玩家游戏失败。 另外,如果只剩一个数字,按位异或运算得到它本身;如果无数字剩余,按位异或运算结果为 0。
并且,轮到某个玩家时,如果当前黑板上所有数字按位异或运算结果等于 0 ,这个玩家获胜。
假设两个玩家每步都使用最优解,当且仅当 Alice 获胜时返回 true。

示例1:
输入: nums = [1,1,2]
输出: false
解释:
Alice 有两个选择: 擦掉数字 1 或 2。
如果擦掉 1, 数组变成 [1, 2]。剩余数字按位异或得到 1 XOR 2 = 3。那么 Bob 可以擦掉任意数字,因为 Alice 会成为擦掉最后一个数字的人,她总是会输。
如果 Alice 擦掉 2,那么数组变成[1, 1]。剩余数字按位异或得到 1 XOR 1 = 0。Alice 仍然会输掉游戏。

示例2:
输入: nums = [0,1]
输出: true

示例 3:
输入: nums = [1,2,3]
输出: true

提示:
1 <= nums.length <= 1000
0 <= nums[i] < 216

在这里插入图片描述

博弈论

如果接触过博弈论,对于这种「判断先手后手的必胜必败」的题目,博弈论方向是一个优先考虑的方向。
根据题意,如果某位玩家在操作前所有数值异或和为0,那么该玩家胜利。要我们判断给定序列时,先手是处于「必胜态」还是「必败态」,如果处于「必胜态」返回 True,否则返回 False。

对于博弈论的题目,通常有两类的思考方式:
经验分析:见过类似的题目,猜一个性质,然后去证明该性质是否可推广。
状态分析:根据题目给定的规则是判断「胜利」还是「失败」来决定优先分析「必胜态」还是「必败态」时具有何种性质,然后证明性质是否可推广。

关于这道题,其实有两种情况需要讨论,第一个给出的数组异或和是否是0.
1.是0时,那么先手直接获胜了返回true,这是必胜情况。
2.不是0时,那么根据题意,都是最优解的拿值,那么肯定谁拿到最后一个值,谁就输。分析谁拿最后一个值,就只需要讨论数组长度的奇偶性就可以了。
奇数Alice 拿到最后一个必输,偶数bob 拿到最后一个,Alice 必赢。

代码:

    public boolean xorGame(int[] nums) {int sum = 0;//先算出异或和,来讨论不同的情况for(int i : nums){sum ^= i;}//和为0 直接获胜,不为0 讨论数组长度奇偶性,奇数输,偶数赢return sum == 0 || nums.length  % 2 == 0;}

动态规划

leetcode375. 猜数字大小 II

http://www.lryc.cn/news/126030.html

相关文章:

  • 算法练习Day48|198.打家劫舍 ● 213.打家劫舍II ● 337.打家劫舍III
  • 什么是设计模式?常用的设计有哪些?
  • clickHouse部署
  • Flutter实现倒计时功能,秒数转时分秒,然后倒计时
  • 【hadoop】windows上hadoop环境的搭建步骤
  • 一周在榜9本计算机专业新书
  • CSS变形与动画(二):perspctive透视效果 与 preserve-3d 3d效果(奥运五环例子)
  • [论文笔记]Glancing Transformer for Non-Autoregressive Neural Machine Translation
  • 视觉学习(七)---Flask 框架下接口调用及python requests 实现json字符串传输
  • unity编写树形结构的文件管理页面
  • 基于单片机的家用智能浇灌系统
  • Solr的入门使用
  • css鼠标样式 cursor: pointer
  • 【解决】Kafka Exception thrown when sending a message with key=‘null‘ 异常
  • 中心极限定理 简明教程
  • 商城-学习整理-基础-库存系统(八)
  • 【C++ 学习 ⑬】- 详解 list 容器
  • 设计模式十五:命令模式(Command Pattern)
  • FPGA GTP全网最细讲解,aurora 8b/10b协议,HDMI视频传输,提供4套工程源码和技术支持
  • 用dcker极简打包java.jar镜像并启动
  • 设计模式——创建型
  • iTOP-i.MX8M开发板添加USB网络设备驱动
  • 分类预测 | MATLAB实现GAPSO-LSSVM多输入分类预测
  • JMeter 的并发设置教程
  • 数据治理有哪些产品
  • windows安装go,以及配置工作区,配置vscode开发环境
  • 第五章nginx负载均衡
  • MATLAB计算一组坐标点的相互距离(pdist、squareform、pdist2函数)
  • 我国农机自动驾驶系统需求日益增长,北斗系统赋能精准农业
  • 防雷检测行业应用完整解决方案