算法基础之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");
  }
相关推荐
Fantasydg40 分钟前
DAY 31 leetcode 142--链表.环形链表
算法·leetcode·链表
basketball61644 分钟前
C++ STL常用算法之常用排序算法
c++·算法·排序算法
moz与京1 小时前
[附C++,JS,Python题解] Leetcode 面试150题(10)——轮转数组
c++·python·leetcode
qystca1 小时前
蓝桥云客 岛屿个数
算法·dfs·bfs
什码情况2 小时前
回文时间 - 携程机试真题题解
数据结构·python·算法·华为od·机试
lwewan3 小时前
26考研——栈、队列和数组_数组和特殊矩阵(3)
数据结构·笔记·考研·算法
晚雾也有归处3 小时前
链表(C++)
数据结构·c++·链表
拾零吖3 小时前
枚举算法-day2
数据结构·算法·leetcode
已经成为了代码的形状3 小时前
关于交换并查集内元素的一些题的做法
数据结构·算法
勘察加熊人3 小时前
c++实现录音系统
开发语言·c++