当前位置: 首页 > news >正文

C++ 数论相关题目 博弈论:拆分-Nim游戏

给定 n
堆石子,两位玩家轮流操作,每次操作可以取走其中的一堆石子,然后放入两堆规模更小的石子(新堆规模可以为 0
,且两个新堆的石子总数可以大于取走的那堆石子数),最后无法进行操作的人视为失败。

问如果两人都采用最优策略,先手是否必胜。

输入格式
第一行包含整数 n

第二行包含 n
个整数,其中第 i
个整数表示第 i
堆石子的数量 ai

输出格式
如果先手方必胜,则输出 Yes。

否则,输出 No。

数据范围
1≤n,ai≤100
输入样例:
2
2 3
输出样例:
Yes
在这里插入图片描述

#include <iostream>
#include <algorithm>
#include <cstring>
#include <unordered_set>using namespace std;const int N = 110;
int n;
int f[N];//存i个状态的sg值int sg(int x)
{if(f[x] != -1) return f[x];unordered_set<int> S; //哈希表存储每个局面可以到的局面//这个地方特别关键:在集合的Nim游戏中,我们可以明显的知道可以到的下一个状态是什么//比如(x - s[i]),这道题里面需要遍历一下所有可能到达的状态,并且异或起来for(int i = 0; i < x; i ++ )for(int j = 0; j <= i; j ++) //用i和j表示分成的两个状态S.insert(sg(i) ^ sg(j));for(int i = 0; ; i ++ )if(!S.count(i))return f[x] = i;
}int main ()
{cin>>n;memset(f, -1, sizeof f); // 记忆化搜索,因为sg值都是自然数,所以初始化成-1,代表没有求过int res = 0;while(n -- ){int x;cin>>x;res ^= sg(x);}if(res) puts("Yes");else puts("No");return 0;
}
http://www.lryc.cn/news/291418.html

相关文章:

  • EDR、SIEM、SOAR 和 XDR 的区别
  • 修复idea,eclipse ,clion控制台中文乱码
  • 怎样使用Oxygen XML Editor将MS Word转换成DITA
  • 【云上建站】快速在云上构建个人网站3——网站选型和搭建
  • 给你一个未排序的整数数组 nums ,请你找出其中没有出现的最小的正整数
  • C#使用RabbitMQ-4_路由模式(直连交换机)
  • PyTorch 之 nn.Parameter
  • KAFKA高可用架构涉及常用功能整理
  • 3d模型上的材质怎么删除---模大狮模型网
  • leetcode hot100跳跃游戏Ⅱ
  • 大数据期望最大化(EM)算法:从理论到实战全解析
  • 【鸿蒙】大模型对话应用(二):对话界面设计与实现
  • MySQL 导入数据
  • 探索数字经济:从基础到前沿的奇妙旅程
  • 【INTEL(ALTERA)】如何在 Windows 操作系统上设置 Design Space Explorer II 远程 SSH 场
  • Python编程-使用urllib进行网络爬虫常用内容梳理
  • 01 Redis的特性+下载安装启动+Redis自动启动+客户端连接
  • C++发起Https请求
  • 哪款笔记软件支持电脑和手机互通数据?
  • 部署PXE高效批量网络装机
  • 【JavaEE】UDP协议与TCP协议
  • Leetcode—1828. 统计一个圆中点的数目【中等】
  • 新概念英语第二册(47)
  • 抽象类(Java)、模板方法设计模式
  • 【Delphi】IDE 工具栏错乱恢复
  • 自动化报告的前奏|使用python-pptx操作PPT(一)
  • 2024美赛数学建模D题思路+代码
  • JDBC 结构优化2
  • 大模型相关术语
  • 数据库之九 流程控制、存储过程和函数