AGC005 部分简要题解
E
首先注意到这个问题事实上非常复杂(两棵树上博弈),基础的转化无效,于是考虑简化情形。
手玩很多样例可以发现,似乎很容易出现无限循环的情况,进一步地,有观察:
- 若第一棵树上存在相邻点 \(u, v\) 在第二棵树上距离 \(> 2\),那么只要走到 \(u, v\) 其中一个点先手一定存在策略能够无限循环下去。
显然走到哪个点是对称的,不妨假设走到 \(u\)。
那么先手可以在后手走到 \(u\) 在第二棵树上相邻点时移动到 \(v\),由于树上路径唯一,后手不可能在一次操作内移动到 \(v\)。
借此,我们将满足上述情形的点对称作关键点,它们的连边称作关键边。
注意到我们不需要考虑关键边(因为走了关键边必定在此之前走到了关键点),于是我们将关键边全部删去,第一棵树变为森林,此时问题转化为:
- 先手从 \(X\) 开始走,走到关键点赢,后手从 \(Y\) 开始追赶 \(X\) 碰到了后手赢(先手无法赢的时候尽可能最大化步数,后手尽可能最小化步数)。确定双方谁赢并且在后手赢的时候输出最大步数。
由于此时第一棵树上的连边在第二棵树上距离 \(\le 2\),因此考虑以第二棵树为主树将第一棵树在其上连虚边(这样方便观察)。
此时貌似仍然没有头绪,考虑 弱化问题:所有第一棵树上连边在第二棵树上距离 \(=1\)。
此时显然有如下观察(证明不难):
- 后手每次的最优策略一定是向先手方向移动。
- 先手的最优策略一定是走到一个不会在路径过程中被后手撞到的(最远)位置然后乖乖等死,或找到一个不会在路径过程中被后手撞到的关键点(优先)。
对于后者,不难发现这些位置 \(u\) 满足:\(dis_{X, u} < dis_{Y, u}\)。
充分性显然,必要性可以考虑先手的最优策略。
那么找到满足上述条件点中 \(dis_{Y, u}\) 的最大值即可,答案就是其的两倍。
回到原问题,我们做类似的观察可以发现先手后手的最优策略与弱化问题一致!
我们容易证明:先手在与后手距离 \(\le 2\) 的时候最优策略是远离先手 / 不动(无路可走)。
因此可以证明先手的最优策略。
而后手的最优策略显然是先手最优策略下的答案上界。
因此只需要找到可行点的判定条件即可。
不难发现,此时一个点可行当且仅当:
- 其在第一棵树上的所有祖先(以 \(X\) 为根)\(u\)(包含其本身)满足:\(disA_{X, u} < disB_{Y, u}\)
充分性考虑归纳证明。
必要性容易通过先手在与后手距离 \(\le 2\) 的时的必胜策略证明(先手不会在 \(\ge\) 的位置继续向后手靠近)
于是直接找到上述的可行点判定先手是否赢 / 后手赢情况下的最多次数即可。
复杂度 \(\mathcal{O}(n \log n)\),瓶颈在于求树上两点距离,当然本题中只需要判定距离是否 \(\le 2\),于是可以容易优化至 \(\mathcal{O}(n)\),但没太大必要。
AGC005 部分简要题解的更多相关文章
- Noip 2014酱油记+简要题解
好吧,day2T1把d默认为1也是醉了,现在只能期待数据弱然后怒卡一等线吧QAQ Day0 第一次下午出发啊真是不错,才2小时左右就到了233,在车上把sao和fate补掉就到了= = 然后到宾馆之后 ...
- Tsinghua 2018 DSA PA2简要题解
反正没时间写,先把简要题解(嘴巴A题)都给他写了记录一下. upd:任务倒是完成了,我也自闭了. CST2018 2-1 Meteorites: 乘法版的石子合并,堆 + 高精度. 写起来有点烦貌似. ...
- Codeforces 863 简要题解
文章目录 A题 B题 C题 D题 E题 F题 G题 传送门 简要题解?因为最后一题太毒不想写了所以其实是部分题解... A题 传送门 题意简述:给你一个数,问你能不能通过加前导000使其成为一个回文数 ...
- HNOI2018简要题解
HNOI2018简要题解 D1T1 寻宝游戏 题意 某大学每年都会有一次 Mystery Hunt 的活动,玩家需要根据设置的线索解谜,找到宝藏的位置,前一年获胜的队伍可以获得这一年出题的机会. 作为 ...
- JXOI2018简要题解
JXOI2018简要题解 T1 排序问题 题意 九条可怜是一个热爱思考的女孩子. 九条可怜最近正在研究各种排序的性质,她发现了一种很有趣的排序方法: Gobo sort ! Gobo sort 的算法 ...
- BJOI2018简要题解
BJOI2018简要题解 D1T1 二进制 题意 pupil 发现对于一个十进制数,无论怎么将其的数字重新排列,均不影响其是不是 \(3\) 的倍数.他想研究对于二进制,是否也有类似的性质. 于是他生 ...
- CQOI2018简要题解
CQOI2018简要题解 D1T1 破解 D-H 协议 题意 Diffie-Hellman 密钥交换协议是一种简单有效的密钥交换方法.它可以让通讯双方在没有事先约定密钥(密码)的情况下,通过不安全的信 ...
- AtCoder ExaWizards 2019 简要题解
AtCoder ExaWizards 2019 简要题解 Tags:题解 link:https://atcoder.jp/contests/exawizards2019 很水的一场ARC啊,随随便便就 ...
- Comet OJ - Contest #2 简要题解
Comet OJ - Contest #2 简要题解 cometoj A 模拟,复杂度是对数级的. code B 易知\(p\in[l,r]\),且最终的利润关于\(p\)的表达式为\(\frac{( ...
随机推荐
- libecc:一个可移植的椭圆曲线密码学库
libecc:一个可移植的椭圆曲线密码学库 这段时间要写毕设关于椭圆曲线的部分,就参考了一个椭圆曲线库的代码来编写.这个库中的代码的结构.风格和封装在我看来是十分完善的.用起来也比较方便,当作一个密码 ...
- MySQL高级查询与编程笔记 • 【第1章 数据库设计原理与实战】
全部章节 >>>> 本章目录 1.1 数据需求分析 1.1.1 数据需求分析的定义 1.1.2 数据需求分析的步骤和方法 1.1.3 数据流程图 1.1.4 数据字典 1. ...
- 【MySQL作业】MySQL函数——美和易思字符串函数应用习题
点击打开所使用到的数据库>>> 1.将所有客户的姓名与电话以"-"作为分隔符进行连接显示. 使用 concat(s1,s2,-) 函数将所有客户的姓名与电话以&q ...
- markdownpad 2 pro版本(注册码)
简介 markdown – 一种轻量级文本标记语言,当今程序员必备技能markdownpad -- windows平台下好用的markdown编辑器 官网下载地址:http://www.markdow ...
- slf4j+logback日志框架 的具体使用操作【spring boot自带的默认日志框架】
1.前言 是不是还在使用System.out.println()打印数据到控制台看? 东西少还好,如果多起来,那就看的很烦人了,特别还有加时间等信息. 怎么解决? 可以使用日志框架 ,常见的有 log ...
- Elasticsearch打造全文搜索引擎(一)
带着问题上路--ES是如何产生的? (1)思考:大规模数据如何检索? 如:当系统数据量上了10亿.100亿条的时候,我们在做系统架构的时候通常会从以下角度去考虑问题: 1)用什么数据库好?(mysq ...
- Spring Security OAuth2 完全解析 (流程/原理/实战定制) —— Client / ResourceServer 篇
一.前言 本文假设读者对 Spring Security 本身原理有一定程度的了解,假设对 OAuth2 规范流程.Jwt 有基础了解,以此来对 SpringSecurity 整合 OAuth2 有个 ...
- Pop Sequeue
题目描述 Given a stack which can keep M numbers at most. Push N numbers in the order of 1,2,3...,N and p ...
- Keil MDK STM32系列(六) 基于抽象外设库HAL的ADC模数转换
Keil MDK STM32系列 Keil MDK STM32系列(一) 基于标准外设库SPL的STM32F103开发 Keil MDK STM32系列(二) 基于标准外设库SPL的STM32F401 ...
- [STM32F10x] 使用printf函数进行串口调试问题
硬件:STM32F103C8T6 平台:Keil ARM-MDk V5.11 利用printf函数通过串口(USART)进行调试时遇到的一个问题: printf("Hello, Mini-M ...