算法基础之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");
  }
相关推荐
stanleyrain10 分钟前
c++指针问题
开发语言·c++
如意.75918 分钟前
【C++】从 I0 库到缓冲区,一篇吃透输入输出
开发语言·c++
小李小李快乐不已34 分钟前
哈希表理论基础
数据结构·c++·哈希算法·散列表
AuroraWanderll35 分钟前
C++11(二)核心突破:右值引用与移动语义(上)
c语言·数据结构·c++·算法·stl
CoderYanger35 分钟前
第 479 场周赛Q1——3769. 二进制反射排序
java·数据结构·算法·leetcode·职场和发展
广府早茶36 分钟前
机器人重量
c++·算法
神仙别闹37 分钟前
基于QT(C++)实现宠物小精灵对战游戏
c++·qt·宠物
sin_hielo39 分钟前
leetcode 1925
数据结构·算法·leetcode
CoderYanger41 分钟前
A.每日一题——1925. 统计平方和三元组的数目
java·开发语言·数据结构·算法·leetcode·哈希算法
小白程序员成长日记42 分钟前
2025.12.08 力扣每日一题
java·算法·leetcode