最近刚学了博弈论,拿来练练手qwq
其实和数值的大小并没有关系
我们用$N/P$态来表示必胜/必败状态
先在草稿纸上探究硬币在最左侧(其实左右侧是等价的)的一条长链的$N/P$态,设链长为$n$
我们用$1$代替其他所有非$0$数
$n=2: 11$ $N$态
$n=3: 111$ $P$态
......
我们发现,当$n$为奇数时,则为$P$态,反之为$N$态。
于是我们就找到了硬币在最左侧时的答案。
但是,实际上硬币并不一定在最左侧
此时我们只需要分别判断硬币左边的链和硬币右边的链,只要有一种为$N$态,则Alice赢,反之Bob赢(双方都会选择最优走法)。
代码如下:
#include<iostream> #include<cstdio> using namespace std; int a[43],n,l=1,r=1; //记得要算上硬币所在的点 int main() { scanf("%d",&n); for(int i=1;i<=n;++i) scanf("%d",&a[i]),a[n+i]=a[i]; for(int i=n;a[i];--i) ++l; //左侧判断 for(int i=n+1;a[i];++i) ++r; //右侧判断 if((l&1)&&(r&1)) printf("NO"); //任何一个为奇数则Alice赢 else printf("YES"); return 0; }
继续阅读与本文标签相同的文章
上一篇 :
python 之信号Signal
下一篇 :
机器人,英伟达的下一场革命
-
开发函数计算的正确姿势 —— 使用 Fun Build 构建函数
2026-05-18栏目: 教程
-
开发函数计算的正确姿势 —— 使用 ROS 进行资源编排
2026-05-18栏目: 教程
-
阿里云InfluxDB®基于TSI索引的数据查询流程
2026-05-18栏目: 教程
-
开发函数计算的正确姿势 —— 依赖安装方法一览
2026-05-18栏目: 教程
-
支付宝小程序“开闸放粮”,亿级流量扶持中小商家!
2026-05-18栏目: 教程
