[hdu4388]Stone Game II

本文探讨了在不使用特殊技能的情况下,通过将原问题转化为Nim游戏的策略来解决堆石子问题。核心思路在于观察到操作前后堆的二进制表示中1的个数总和保持不变,从而简化问题并找到解决方案。

不管是否使用技能,发现操作前后所有堆二进制中1的个数之和不变。那么对于一个堆其实可以等价转换为一个k个石子的堆(k为该数二进制的个数),然后就是个nim游戏。

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 int t,n,ans,a[101];
 4 int main(){
 5     scanf("%d",&t);
 6     for(int ii=1;ii<=t;ii++){
 7         scanf("%d",&n);
 8         for(int i=1;i<=n;i++)scanf("%d",&a[i]);
 9         ans=n%2;
10         for(int i=1;i<=n;i++)
11             while (a[i]){
12                 ans^=a[i]%2;
13                 a[i]>>=1;
14             }
15         if (ans)printf("Case %d: Yes\n",ii);
16         else printf("Case %d: No\n",ii);
17     }
18 }
View Code

 

转载于:https://www.cnblogs.com/PYWBKTDA/p/11254631.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值