算法基础之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");
  }
相关推荐
不会c嘎嘎9 分钟前
C++ -- stack和queue
开发语言·c++·rpc
CodeByV16 分钟前
【C++】C++11:其他重要特性
开发语言·c++
2501_9411113325 分钟前
C++代码重构实战
开发语言·c++·算法
一叶之秋141226 分钟前
从零开始:打造属于你的链式二叉树
数据结构·算法
爱装代码的小瓶子31 分钟前
【c++知识铺子】相对简单的容器适配器双生子-stack和queue(STL)
开发语言·c++
CoovallyAIHub33 分钟前
CV研究告别数据荒?PAN世界模型实现「多步推理与规划」,可自造高质量训练数据
深度学习·算法·计算机视觉
脏脏a1 小时前
类和对象(下):初始化列表、静态成员与友元深度解析
开发语言·c++
Dream it possible!1 小时前
LeetCode 面试经典 150_二叉树_二叉树中的最大路径和(77_124_C++_困难)(DFS)
c++·leetcode·面试·二叉树
2501_941111681 小时前
模板编译期哈希计算
开发语言·c++·算法