【数学】【位运算】LeetCoce810. 黑板异或游戏

简介: 【数学】【位运算】LeetCoce810. 黑板异或游戏

本文涉及知识点

数学 位运算

LeetCoce810. 黑板异或游戏

黑板上写着一个非负整数数组 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

数学

排除首回合,其它回合开始,所有数的异或和x不会是0。如果选取x,则异或和一定为0。不选择x,异或和一定不为0。显然只有所有数全部是x的才会必定失败。偶数个x的异或和为0,除首回合外,不会存在,故偶数个数的时候,必定不败。 奇数个数的玩家必败,等数的数量降低到1时,必败。

以下两种情况之一返回ture:

一,nums的⊕ \oplus 为0。

二,nums.size为偶数。

代码

class Solution {
public:
    bool xorGame(vector<int>& nums) {
int xorSum = 0 ;
for(const auto& n : nums )
{
    xorSum ^= n ;
}
return (0==xorSum) || ( 0 == nums.size()%2);
    }
};


扩展阅读

视频课程

有效学习:明确的目标 及时的反馈 拉伸区(难度合适),可以先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。

https://edu.csdn.net/course/detail/38771

如何你想快

速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程

https://edu.csdn.net/lecturer/6176

相关

下载

想高屋建瓴的学习算法,请下载《喜缺全书算法册》doc版

https://download.csdn.net/download/he_zhidan/88348653

我想对大家说的话
闻缺陷则喜是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。
子墨子言之:事无终始,无务多业。也就是我们常说的专业的人做专业的事。
如果程序是一条龙,那算法就是他的是睛

测试环境

操作系统:win7 开发环境: VS2019 C++17

或者 操作系统:win10 开发环境: VS2022 C++17

如无特殊说明,本算法用**C++**实现。

目录
打赏
0
0
0
0
36
分享
相关文章
C语言第二十七练 异或的运算规律
C语言第二十七练 异或的运算规律
80 0
【漫步刷题路】-位运算-求1到n异或的结果
规律总结: 每四个数是一个循环 且循环规律为: 1 ,n+1 ,0, n
217 0
【漫步刷题路】-位运算-求1到n异或的结果
每日算法系列【LeetCode 810】黑板异或游戏
每日算法系列【LeetCode 810】黑板异或游戏
100 0
|
10月前
【错题集-编程题】素数回文(模拟 + 数学)
【错题集-编程题】素数回文(模拟 + 数学)
移位运算、位运算、逻辑运算相关知识点及笔试题
移位运算、位运算、逻辑运算相关知识点及笔试题
317 0
移位运算、位运算、逻辑运算相关知识点及笔试题
位运算入门及简单算法题的应用
位运算入门及简单算法题的应用
68 1
【漫步刷题路】-位运算x&(-x)的妙用
当x为奇数时:结果为1 当x为0时 :结果为0 当x为偶数时:得到的是能整除这个偶数的最大的二次幂 **当x为2的幂次方时候(偶数)-> 则x&(-x) == x 得到的能整除这个偶数的最大的二次幂就算本身 **
148 0
【漫步刷题路】-位运算x&(-x)的妙用
|
10月前
|
算法编程(十四):颠倒二进制位
算法编程(十四):颠倒二进制位
81 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等