算法基础之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");
  }
相关推荐
foundbug9991 天前
STM32 内部温度传感器测量程序(标准库函数版)
stm32·单片机·嵌入式硬件·算法
Hello.Reader1 天前
为什么学线性代数(一)
线性代数·算法·机器学习
code_whiter1 天前
C++6(模板)
开发语言·c++
_深海凉_1 天前
LeetCode热题100-找到字符串中所有字母异位词
算法·leetcode·职场和发展
一只旭宝1 天前
【C++ 入门精讲1】初始化、const、引用、内联函数 | 超详细手写笔记(附完整代码)
开发语言·c++
木井巳1 天前
【递归算法】目标和
java·算法·leetcode·决策树·深度优先
旖-旎1 天前
哈希表(字母异位次分组)(5)
数据结构·c++·算法·leetcode·哈希算法·散列表
别或许1 天前
4、高数----一元函数微分学的计算
人工智能·算法·机器学习
_深海凉_1 天前
LeetCode热题100-最长连续序列
算法·leetcode·职场和发展
这里没有酒1 天前
[信息安全] AES128 加密/解密 --> state 矩阵
算法