HDU4388-Stone Game II-Nim变形
http://acm.hdu.edu.cn/showproblem.php?pid=4388
Nim变形,对一个\(n\)个石子的堆,每次取\(k(0<k<n)\)个(注意不能全取光),同时要保证\(n\oplus k<n\),并添加一堆新的大小为\(n\oplus k\)的石子。
同时每个人在整个游戏中还有一次机会把添加的大小为\(n\oplus k\)的石子改为\(n\oplus (2k)\)个石子,同样是不能操作的输,两个人采取最优策略。
初步想法
一般性地,我们还是先不管\(n\oplus k\)变成\(n\oplus(2k)\)这个操作,先想清楚没有这种操作的情况
很自然地去手算几个小数据,以及往二进制的方向想(毕竟异或都出来了),\(n=1,2\)都直接不能操作,\(n=3=(11)_2\)的时候可以取一个\(k=1\)或者\(k=2\),接下来\(k=4=(100)_2\)又不能操作了…
仔细想想就会发现对于一个\(2^k=(\underbrace{100\dots00}_{k个0})_2\)不管怎么取一个比\(n\)小的\(k\),异或之后一定比\(n\)大,所以对于一堆的\(2^k\)就是一个不能操作的状态。同样如果是\((100\dots 010\dots 00)_2\)这样的东西,只要取一个\(k=(100\dots000\dots00),n\oplus k=(000\dots010\dots00)_2\)一定是满足条件的。
(也就是从\(n\)的1里面选一些1出来当\(k\),剩下\(n\oplus k\)一定是小于\(n\)的)
于是有了初步的想法,二进制表示下\(m\)个1的\(n\)至少可以按照这种拆法拆\(m-1\)次
进一步如果这么拆,当\(m\)是奇数时先手必败,否则必胜
进一步
不过仔细想想好像也不一定要那么拆,比如:
\]
5位→2位+5位,4次→1次+4次=5次,嗯?乍一看好像上面那样优雅的结论被破坏掉了…(当时推到这里差点放弃前面的思路…)冷静想一想,一次操作改变奇偶性…这不还是很河里嘛…(先手奇→留给后手偶)
而且虽然1的个数变多了,但是其实在两个人都采取最优策略的情况下具有必胜策略的那个人其实每次单独拿一个\(2^k\)出来就总是能把1的个数降下来…所以终究是能把游戏结束掉
证明一下?
似乎不管怎么拆,每次拆完都会改变奇偶性。怎么证呢…
- 考虑某一位\(p\),如果\(n\)的这一位为1,\(p\)的为0,那么\(n\oplus k\)的结果是1
- 类似地,列出四种情况,奇偶性一定不变
为什么呢…好像很显然…因为异或本来就是模二意义下的加法…奇偶性当然不变了…
证明了个寂寞
于是有结论:\(n\)中1的个数和\(k\)与\(n\oplus k\)中1的个数之和的奇偶性相同
好像快做完了
这么看来好像\(n\oplus k\to n\oplus (2k)\)就是纯粹拿来唬人的呀…毕竟奇偶性还是不变(因为\(k\)和\(2k\)中的1的个数是一样的,再套用上面的结论)
于是就愉快地做完了
根据初始状态算出来“能进行操作的次数”,判一下奇偶性
#include<bits/stdc++.h>
#define rep(i,a,b) for(int i=(a);i<=(b);i++)
const int N=1e5+5;
int f[N];
inline int calc(int x)
{
if(f[x])return f[x];
int r=0;
while(x){if(x&1)r++;x>>=1;}
return f[x]=r;
}
int main()
{
int T;scanf("%d",&T);
rep(tc,1,T)
{
int n,r=0;
scanf("%d",&n);
rep(i,1,n)
{
int a;scanf("%d",&a);
r+=calc(a)-1;
}
printf("Case %d: ",tc);
if(r&1)printf("Yes\n");
else printf("No\n");
}
}
HDU4388-Stone Game II-Nim变形的更多相关文章
- [hdu4388]Stone Game II
不管是否使用技能,发现操作前后所有堆二进制中1的个数之和不变.那么对于一个堆其实可以等价转换为一个k个石子的堆(k为该数二进制的个数),然后就是个nim游戏. 1 #include<bits/s ...
- HDU4388:Stone Game II(博弈+思维)
Stone Game II Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tot ...
- HDU 3094 树上删边 NIM变形
基本的树上删边游戏 写过很多遍了 /** @Date : 2017-10-13 18:19:37 * @FileName: HDU 3094 树上删边 NIM变形.cpp * @Platform: W ...
- hdu 4388 Stone Game II sg函数 博弈
Stone Game II comes. It needs two players to play this game. There are some piles of stones on the d ...
- hdu 4388 Stone Game II
Stone Game II HDU - 4388 题目大意: 给出n堆物品,每堆物品都有若干件,现在A和B进行游戏,每人每轮操作一次,按照如下规则: 1. 任意选择一个堆,假设该堆有x个物品,从中选择 ...
- HDU 4388 Stone Game II {博弈||找规律}
Stone Game II Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tot ...
- Leetcode--Last Stone Weight II
Last Stone Weight II 欢迎关注H寻梦人公众号 You are given an array of integers stones where stones[i] is the we ...
- ZOJ 3964 NIM变形
LINK 题意:n堆石子,Alice 和 Bob 轮流取石子,谁不能再取或被对方取完为败.但是对于alice拥有限制:b=0此堆正常无限制:b=1此堆Alice只能取奇数个石子:b=2只能取偶数个石子 ...
- LeetCode 1049. Last Stone Weight II
原题链接在这里:https://leetcode.com/problems/last-stone-weight-ii/ 题目: We have a collection of rocks, each ...
- LeetCode 1140. Stone Game II
原题链接在这里:https://leetcode.com/problems/stone-game-ii/ 题目: Alex and Lee continue their games with pile ...
随机推荐
- netsniff使用
1 netsniff安装与使用 首先直接下载源码包进行部署 安装一些前置包(安装完成的自动忽略) sudo apt install pkg-config sudo apt install libcli ...
- guitar pro系列教程(二十四):Guitar Pro 7 中文界面的介绍
用过Guitar Pro这款软件的小伙伴们都知道,Guitar Pro这款吉他软件因为是国外开发商研发的,所以软件最初都是英文版本,对于国内的的吉他爱好者来说,在软件使用上还是很不方便的.随着Guit ...
- leetcode133. 克隆图
给定无向连通图中一个节点的引用,返回该图的深拷贝(克隆).图中的每个节点都包含它的值 val(Int) 和其邻居的列表(list[Node]).示例: 输入:{"$id":&quo ...
- win10一行代码搭建本地html项目
最近玩了下web项目,需要部署到本地查看效果. 一:准备 1.安装python或者安装node.js 2.html项目文件 二:python搭建 1.进入html文件的路径 2.通过python命令部 ...
- LeetCode周赛#205
5508. 数的平方等于两数乘积的方法数 #模拟 #哈希表 题目链接 题意 给你两个整数数组nums1 和 nums2 ,请你返回根据以下规则形成的三元组的数目(类型 1 和类型 2 ): 类型 1: ...
- Image Inpainting with Learnable Bidirectional Attention Maps
Image Inpainting with Learnable Bidirectional Attention Maps pytorch 引言 部分卷积(PConv)的缺陷: 1 将含有1个有效值像素 ...
- java47
1. 1.List集合根据角标获取元素 import java.util.ArrayList; import java.util.List; public class List集合 { @Suppre ...
- Eclipse的新建工作空间如何用以前工作空间的配置
1.找到以前工作空间的配置目录:\.metadata\.plugins\org.eclipse.core.runtime 2.替换掉新的工作空间的配置目录:\.metadata\.plugins\or ...
- Spark存储Parquet数据到Hive,对map、array、struct字段类型的处理
利用Spark往Hive中存储parquet数据,针对一些复杂数据类型如map.array.struct的处理遇到的问题? 为了更好的说明导致问题的原因.现象以及解决方案,首先看下述示例: -- 创建 ...
- 技巧收藏|10个JavaScript常用数组操作方法
摘要:这篇文章,向大家展示了在日常开发中,数组有哪些小技巧值得借鉴和学习. 在web前端开发第二阶段Javascript中,数组是一个重要且常见的知识点,我们经常将数据存储在数组中,遍历数组或替换数组 ...