算法基础之Nim游戏

Nim游戏

  • 核心思想:博弈论

    • 结论:将所有堆的石子数全部异或起来 得到的结果
    • 若为1 则先手必胜 若为0 则先手必败
cpp 复制代码
  #include <iostream>
  #include <cstring>
  #include <algorithm>
  
  using namespace std;
  const int N = 100010;
  
  int a[N];
  int n;
  
  int main()
  {
      cin>>n;
      int x;
      cin>>x;
      int res = x;
      for(int i=1;i<n;i++) cin>>x, res ^= x;
      
      if(res) puts("Yes");
      else puts("No");
  }
相关推荐
YuanDaima204812 小时前
双指针基础原理与题目说明
数据结构·人工智能·python·算法·leetcode·手撕代码
别或许12 小时前
5、高数----一元函数微分学的应用(一)几何应用
算法
wayz1112 小时前
Day 5:KNN算法与相似K线匹配
人工智能·算法·机器学习
晨曦中的暮雨13 小时前
Java集合类型主要有哪些?以及各自原理
数据结构·算法
lixinnnn.13 小时前
01BFS:Three States
算法
晓纪同学13 小时前
EffctiveC++_第三章_资源管理
开发语言·c++·算法
沐雪轻挽萤13 小时前
6. C++17新特性-编译期 if 语句 (if constexpr)
开发语言·c++
水云桐程序员13 小时前
C语言编程基础,输入与输出
c语言·开发语言·算法
ZPC821013 小时前
MoveIt Servo 与自己编写的 Action Server 通信
人工智能·算法·机器人
jllllyuz13 小时前
采用核函数的极限学习机(KELM)MATLAB实现
算法