欢迎来看 “片” (的简介)
由于-\(看片\)-生涯转瞬即逝,于是我选择对“\(片\)”进行一定的总结:
相信你一定看懂了
由于开始的时间有一点晚,就姑且认为我以后会慢慢补充吧......
\(P6970\) \([NEERC2016]\) \(Game\) \(on\) \(Graph\)
解:博弈论
首先,我们有更原始的问题:
\(A\), \(B\) 在 \(DAG\) van 游戏,二者都想赢,\(A\) 先手,问哪些点上有制胜策略
很简单,我们可以发现一个点与之相连的所有点种如果全都是必胜的,就好比你一个天天撸管的人在一群NOI金牌面前一样,你就是个废物,所以这个点就是必败点,反之,如果里面有一个点跟你一样是个废物,即必败点,你就可以拿着它垫背,那你肯定会把这个点留给后者,也就是必胜点。
实现方面类似拓扑排序,因为如果没有出度,那肯定是负,然后往上推就可以了,同时,注意一下要建反图。
回到原题,这里唯一的区别就是胜,平,负的顺序变了,我们把定义也改了,就行了,不过在此之前还要看一下平局的情况,因为这道题是可以有环段的。
首先平局就是那些不能被 \(0/1\) 定义,即胜负定义的点,那么非常简单,如果对于先手而言,如果子节点种有不确定的,那这个点就跟着不确定,即平,反之,对于后手而言,只有在全是平手的时候选择不确定,即平,其它依旧。
然而,我们都强调了,不确定不确定,但我们可以知道的是,对于先手而言,只要子节点有不确定的,就不确定,所以我们只需要确定 \(0/1\) 即可,剩余的全是平手。而对于后手而言,也可以通过只看 \(0/1\) 胜负来判定。于是平的情况就被解决了。
相信你一定已经开始写了,相信你也一定为实现感到困恼,不妨借鉴 (Ctrl+C,Ctrl+V 一下大佬的写法,复述一下他的做法:
题解中的 \(vis_{i,0/1}\) 在能判定一个点有没有被询问过的同时,还清楚的告诉了你它的答案,因为我们知道,对于 \(B\) (即题目中的 \(Georgiy\))而言,只要它儿子中的所有节点有其中一个为负,则必然它会去取之并变成胜,所以将这一个点设为胜,反之对于 \(A\) (即题目中的 \(Gennady\)) 的情况,只有对于所有点被取完的时候才能这么做。
更细致地说,在 \(dfs\) 的过程中,要不断地交换当前的先后手情况,而 \(vis\) 在访问与否的意义下不变,然而在答案的意义下有所变化,对于先手为 \(A\) 而言,\(vis\) 为 \(1\) 是败,为 \(0\) 反倒是胜,而对于 \(B\) 而言就是反过来的,在第一次,以 \(A\) 为先手的 \(dfs\) 情况下,就可以把所有的答案为胜负的情况算出来,后者的 \(dfs\) 则可以把所有平手情况算出来。
如果你渐渐觉得混沌的话,记住最开始的意义:
- \(0/1\) 就是 \(A/B\) 的先手情况;
- \(0/1\) 对应的答案一个是 \(1\) 对负, 一个是 \(0\) 对胜;
- 对于 \(1\) 而言,它的答案一定只有在其他的点都被访问过且都不再是为平的情况下且为胜的时候才能是 \(1\), 而对于 \(0\) 的情况下,则只需要保证其中一个为 \(0\) 就可以为胜。
其他的思考:
-
为什么遇到一个 \(A\) 就可以判定它一定是负?因为由于我们是 \(0/1\) 交错的,因此一旦遇到一个合法的 \(A\) 就能说明它周围一定是 \(B\), 且全都是胜,故这一个 \(A\) 一定是负。
-
为什么第一个 \(dfs\) 可以把所有的胜负情况全算出来? 因为我们第一次 \(dfs\) 判断的就是 \(A\) 为先手负的情况和 \(B\) 为先手为胜的情况,两种情况在图上相互关联且不存在其它情况与之联系,所以说如果这样做就只会把这种情况找出来,那么就只会把上述情况找出来,又因为非胜即负或平,所以第二层循环只用把能否找到的情况判了,也就是判断是胜负还是平局。
\(AT\)\(agc002\)\(e\) \([AGC002E]\) \(Candy\) \(Piles\)
解:适当的画画,博弈
我们先把石子按从大到小的顺序排个序,如下图:
你一定以为我用的是 \(IOS\),那你高估了 \(GF\) 的实力了
那我们的操作就变得有所规律了:
\(\textcolor{green}{绿}\)色就是操作 \(1\), \(\textcolor{orange}{橙}\)色就是操作 \(2\),我们现在只观察左下角的石头,可以发现这样的操作相当于就是让一个 \(BOT\) 从左下角直走上和右不停地走到边缘的操作。我们知道最边缘的且无法操作的石头由于是最后一个所以一定是负,对于上和右两个石头只要有一个是负那当前这一个点就是胜,反之,只有当上和右两个石头都是胜的时候当前这个点才是负,于是从最外层往里面推,就有下面这个图 \(\textcolor{green}{绿}\)是胜,\(\textcolor{red}{红}\)是输:
不难发现, 对角线上的值是相同的。
那我们就找到一左下角为顶点的最大正方形的右上角定点的胜负情况,可以发现它就是这个正方形的边长与边长对应下标的石子长度的差的奇偶情况和最长的与边长高度相同的以下一位为开头的前缀长度的奇偶情况的或。
注意一下如果没有合法的正方形的情况。
标签:一个点,对于,胜负,博弈论,dfs,片集,情况,就是,etc From: https://www.cnblogs.com/Aaron-Yao-Aloe/p/18316816