算法基础之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");
  }
相关推荐
小范馆11 分钟前
C++ 编译方法对比:分步编译 vs 一步到位
java·开发语言·c++
云泽80816 分钟前
C++ 继承进阶:默认成员函数、多继承问题与继承组合选型
开发语言·c++
wen__xvn23 分钟前
算法刷题目录
算法
一颗青果25 分钟前
C++下的atomic | atmoic_flag | 内存顺序
java·开发语言·c++
Tisfy26 分钟前
LeetCode 1292.元素和小于等于阈值的正方形的最大边长:二维前缀和(无需二分)+抽象速懂的描述
算法·leetcode·职场和发展
ZPC821031 分钟前
机械臂urdf
人工智能·算法
郝学胜-神的一滴34 分钟前
Python对象的自省机制:深入探索对象的内心世界
开发语言·python·程序人生·算法
跃渊Yuey41 分钟前
【Linux】Linux进程信号产生和保存
linux·c语言·c++·vscode
期待のcode41 分钟前
浅堆深堆与支配树
java·jvm·算法
程序员-King.43 分钟前
day156—回溯—组合总和(LeetCode-216)
算法·leetcode·回溯