算法基础之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");
  }
相关推荐
plus4s4 小时前
2月12日(70-72题)
算法
m0_672703315 小时前
上机练习第24天
算法
Mr_WangAndy5 小时前
C++数据结构与算法_线性表_数组_概念动态数组,刷题
c++·二分查找·数组刷题·数组字符串逆序·零移动·有序数组的平方
阿猿收手吧!5 小时前
【C++】jthread:优雅终止线程新方案
开发语言·c++
edisao5 小时前
序幕-内部审计备忘录
java·jvm·算法
十五年专注C++开发5 小时前
C++中各平台表示Debug的宏
开发语言·c++·debug
shehuiyuelaiyuehao5 小时前
22Java对象的比较
java·python·算法
wanhengidc6 小时前
私有云具体是指什么
服务器·网络·游戏·智能手机·云计算
Dev7z6 小时前
滚压表面强化过程中变形诱导位错演化与梯度晶粒细化机理的数值模拟研究
人工智能·python·算法
吴秋霖6 小时前
apple游客下单逆向分析
python·算法·逆向分析