首页 > 其他分享 >片集 - 思维(博弈论,etc.) - 1

片集 - 思维(博弈论,etc.) - 1

时间:2024-07-22 20:31:49浏览次数:13  
标签:一个点 对于 胜负 博弈论 dfs 片集 情况 就是 etc

欢迎来看 “片” (的简介)

由于-\(看片\)-生涯转瞬即逝,于是我选择对“\(片\)”进行一定的总结:

相信你一定看懂了

由于开始的时间有一点晚,就姑且认为我以后会慢慢补充吧......

\(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\) 则可以把所有平手情况算出来。

如果你渐渐觉得混沌的话,记住最开始的意义:

  1. \(0/1\) 就是 \(A/B\) 的先手情况;
  2. \(0/1\) 对应的答案一个是 \(1\) 对负, 一个是 \(0\) 对胜;
  3. 对于 \(1\) 而言,它的答案一定只有在其他的点都被访问过且都不再是为平的情况下且为胜的时候才能是 \(1\), 而对于 \(0\) 的情况下,则只需要保证其中一个为 \(0\) 就可以为胜。

其他的思考:

  1. 为什么遇到一个 \(A\) 就可以判定它一定是负?因为由于我们是 \(0/1\) 交错的,因此一旦遇到一个合法的 \(A\) 就能说明它周围一定是 \(B\), 且全都是胜,故这一个 \(A\) 一定是负。

  2. 为什么第一个 \(dfs\) 可以把所有的胜负情况全算出来? 因为我们第一次 \(dfs\) 判断的就是 \(A\) 为先手负的情况和 \(B\) 为先手为胜的情况,两种情况在图上相互关联且不存在其它情况与之联系,所以说如果这样做就只会把这种情况找出来,那么就只会把上述情况找出来,又因为非胜即负或平,所以第二层循环只用把能否找到的情况判了,也就是判断是胜负还是平局。

\(AT\)\(agc002\)\(e\) \([AGC002E]\) \(Candy\) \(Piles\)

解:适当的画画,博弈

我们先把石子按从大到小的顺序排个序,如下图:

石堆子1

你一定以为我用的是 \(IOS\),那你高估了 \(GF\) 的实力了

那我们的操作就变得有所规律了:

石堆子2

\(\textcolor{green}{绿}\)色就是操作 \(1\), \(\textcolor{orange}{橙}\)色就是操作 \(2\),我们现在只观察左下角的石头,可以发现这样的操作相当于就是让一个 \(BOT\) 从左下角直走上和右不停地走到边缘的操作。我们知道最边缘的且无法操作的石头由于是最后一个所以一定是负,对于上和右两个石头只要有一个是负那当前这一个点就是胜,反之,只有当上和右两个石头都是胜的时候当前这个点才是负,于是从最外层往里面推,就有下面这个图 \(\textcolor{green}{绿}\)是胜,\(\textcolor{red}{红}\)是输:

石堆子3

不难发现, 对角线上的值是相同的。

那我们就找到一左下角为顶点的最大正方形的右上角定点的胜负情况,可以发现它就是这个正方形的边长与边长对应下标的石子长度的差的奇偶情况和最长的与边长高度相同的以下一位为开头的前缀长度的奇偶情况的或。

注意一下如果没有合法的正方形的情况。

标签:一个点,对于,胜负,博弈论,dfs,片集,情况,就是,etc
From: https://www.cnblogs.com/Aaron-Yao-Aloe/p/18316816

相关文章

  • 片集 - DP - 1
    欢迎来看“片”(的简介)由于-\(看片\)-生涯转瞬即逝,于是我选择对“\(片\)”进行一定的总结:相信你一定看懂了由于开始的时间有一点晚,就姑且认为我以后会慢慢补充吧......\(CF1789F\)\(Serval\)\(and\)\(Brain\)\(Power\)解:DP见过狗的,没见过这么狗的:分\(3\)类讨论:首先......
  • 片集 - 数学 - 1
    欢迎来看“片”(的简介)由于-\(看片\)-生涯转瞬即逝,于是我选择对“\(片\)”进行一定的总结:相信你一定看懂了由于开始的时间有一点晚,就姑且认为我以后会慢慢补充吧......\(P7161\)[\(COCI2020\)\(-\)\(2021\)#\(2\)]\(Euklid\)解:数学\(GCD(a,b)=g\)\(\impliesa=g\time......
  • 片集 - 数据结构 - 1
    欢迎来看“片”(的简介)由于-\(看片\)-生涯转瞬即逝,于是我选择对“\(片\)”进行一定的总结:相信你一定看懂了由于开始的时间有一点晚,就姑且认为我以后会慢慢补充吧......\(CF1270H\)\(Number\)\(of\)\(Components\)解:线段树首先我们可以发现连通块都是以区间的形式存在的......
  • 片集 - 字符串 - 1
    欢迎来看“片”(的简介)由于-\(看片\)-生涯转瞬即逝,于是我选择对“\(片\)”进行一定的总结:相信你一定看懂了由于开始的时间有一点晚,就姑且认为我以后会慢慢补充吧......字典树Trie\(P8306\)\(【模板】\)\(字典树\)解:字典树要不是因为颓废,我早就把这个过了非常简单,就是......
  • 【代码随想录训练营第42期 Day6打卡 LeetCode 242.有效的字母异位词 349.两个数组的交
    目录一、序言二、哈希表的相关知识1.基本概念2.常见的哈希结构3.总结三、题目及其题解242.有效的字母异位词题目链接题解思路1思路2思路3349.两个数组的交集题目链接题解202.快乐数题目链接题解1.两数之和题目链接题解思路1思路2四、小结一、序言......
  • 代码随想录算法训练营第一天leetcode704二分查找27移除元素
    leetcode704,这是leetcode提交四次后通过的结果:classSolution{  publicintsearch(int[]nums,inttarget){    if(nums.length==1&&nums[0]==target)      return 0;    if(nums.length==2)      if(nums[0]==target)......
  • Python学习计划——2.3常用内置函数(len, max, min, sum, etc.)
    Python提供了许多内置函数,用于简化对数据结构的操作。以下是一些常用的内置函数及其详细说明。1.len()len()函数用于返回对象(如列表、元组、字符串、字典等)的长度(元素个数)。示例:#列表fruits=["apple","banana","cherry"]print(len(fruits))#输出:3#元组c......
  • LeetCode 3070. 元素和小于等于 k 的子矩阵的数目
    3070.元素和小于等于k的子矩阵的数目给你一个下标从 0 开始的整数矩阵 grid 和一个整数 k。返回包含 grid 左上角元素、元素和小于或等于 k 的 子矩阵 的数目。示例1:输入:grid=[[7,6,3],[6,6,1]],k=18输出:4解释:如上图所示,只有4个子矩阵满足:包含g......
  • leetcode位运算(1684. 统计一致字符串的数目)
    前言经过前期的基础训练以及部分实战练习,粗略掌握了各种题型的解题思路。后续开始专项练习。描述实现原理与步骤1.本题重点掌握相应字符bit位的编码规则2.bitArray和tempBitArray或之后还等于bitArray,说明bitArray包含tempBitArray代码实现classSolution{publ......
  • dns缓存与/etc/hosts
    **DNS缓存**和**`/etc/hosts`文件**都是用于域名解析的机制,但它们各自的作用和工作原理有所不同。它们在系统中协同工作,以确保域名解析的效率和准确性。以下是它们之间的关系和区别:###DNS缓存**作用**:-DNS缓存用于缓存DNS查询的结果,以提高域名解析速度并减少对DNS服务器的频......