算法基础之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");
  }
相关推荐
Hello eveybody3 分钟前
图论简述+图论考试要点(C++)
c++·深度优先·图论
第二只羽毛4 分钟前
C++高性能内存池6(面试题)
大数据·开发语言·c++
努力的章鱼bro4 分钟前
操作系统-net
c++·操作系统·dma·risc-v
故事和你918 分钟前
洛谷-算法1-1-模拟与高精度4
开发语言·数据结构·c++·算法·蓝桥杯·动态规划
竹之却9 分钟前
【Minecraft】无法连接至服务器,登录失败:无效会话(请尝试重启游戏及启动器)
运维·服务器·游戏·我的世界·minecraft
4ever.ov011 分钟前
Any模拟实现
c语言·数据结构·c++
漫随流水15 分钟前
c++编程:数组元素去重,逆序输出
数据结构·c++·算法
汉克老师17 分钟前
GESP2024年12月认证C++三级( 第一部分选择题(1-8))
c++·字符串·二进制·八进制·补码·gesp三级·gesp3级
m0_7167652322 分钟前
C++基础入门案例--通讯录管理系统详解
开发语言·c++·经验分享·笔记·学习·青少年编程·visual studio
宵时待雨28 分钟前
C++笔记归纳18:C++11
开发语言·c++·笔记