洛谷题面传送门 & Atcoder 题面传送门

记先手移动棋子的树为红树,后手移动棋子的树为蓝树。

首先考虑一个性质,就是如果与当前红色棋子所在的点相连的边中存在一条边,满足这条边的两个端点在蓝树上的距离 \(\ge 3\),那么答案肯定是 \(-1\),因为如果此时红色棋子与蓝色棋子在蓝树上的距离 \(\le 1\),那么先手就可以沿着这条红边将红色棋子移到该边的另一个端点,使红色棋子与蓝色棋子在蓝树上的距离 \(>1\),否则原地不动。如果后手再次将蓝色棋子移到与红色棋子在蓝树上距离为 \(1\) 的位置那先手可以再将棋子沿着这条红边移动 \(1\) 的距离,如此反复进行下去即可。

因此我们考虑先对蓝树进行一遍 DFS 并对每一条红边检验其在蓝树上的距离是否 \(\ge 3\),记 \(ok_x\) 表示是否存在一条与 \(x\) 相连的红边满足其在蓝树上的距离 \(\ge 3\),那么如果先手能够走到一个满足 \(ok_x=1\) 的点,并且下一步还是先手走,那么答案就是 \(-1\)。

那么怎么处理答案不等于 \(-1\) 的情况呢?别急,我们再来找些性质,我们不妨假设现在还不能到达能够无限循环的状态,也就是说所有与当前红色棋子所在点相连的边在蓝树上的距离 \(\le 2\),那么有一个性质是红色棋子肯定不会跨过蓝色棋子,因为如果红色棋子跨过了蓝色棋子,那么此时红色棋子与蓝色棋子距离必然 \(\le 1\),后手必然能在一步之内结束游戏,这显然是先手所不希望看到的。换句话说,任意时刻红色棋子必定在蓝色棋子在蓝树上的子树内,证明可以归纳,读者自证不难。有了这个性质之后我们还能顺带着推出一个性质,那就是记 \(depr_i\) 为 \(i\) 到红树树根的距离,\(depb_i\) 为 \(i\) 到蓝树树根的距离,那么任意时刻如果游戏没有结束,都有 \(depr_x<depb_x\),否则此时此刻红色棋子不在蓝色棋子在蓝树上的子树内,或者两个点位于同一节点上,游戏结束。因此考虑再对红树进行一遍 DFS,如果先手经过 \(depr_x<depb_x\) 的点能够走到 \(ok_x=1\) 的点那么答案就是 \(-1\),否则我们找出红色棋子经过的点中 \(depb\) 的最大值 \(mx\),那么容易证明最优方案是先手将红色棋子移到这个 \(depb\) 最大的点然后原地不动等死,经过的步数为 \(2mx\)。

时间复杂度线性,判断两点在蓝树上距离是否 \(\ge 3\) 不必倍增跳 LCA 求距离,可以直接求出 \(x,y\) 的 \(0,1,2\) 级祖先并判断是否有相同的值。

终于在 NOI 之前把鸽掉的题解全部补完了

const int MAXN=2e5;
int n,x,y;vector<pii> edges_r;
struct graph{
int hd[MAXN+5],to[MAXN*2+5],nxt[MAXN*2+5],ec=0;
void adde(int u,int v){to[++ec]=v;nxt[ec]=hd[u];hd[u]=ec;}
} R,B;
int dep_b[MAXN+5],fa_b[MAXN+5],dep_r[MAXN+5];
void dfs1(int x,int f){
fa_b[x]=f;
for(int e=B.hd[x];e;e=B.nxt[e]){
int y=B.to[e];if(y==f) continue;
dep_b[y]=dep_b[x]+1;dfs1(y,x);
}
}
bool check(int x,int y){
vector<int> fx,fy;
for(int i=0;i<3;i++) fx.pb(x),x=fa_b[x];
for(int i=0;i<3;i++) fy.pb(y),y=fa_b[y];
for(int i=0;i<3;i++) for(int j=0;j+i<3;j++) if(fx[i]==fy[j]) return 0;
return 1;
}
int ans=0,ok[MAXN+5];
void dfs2(int x,int f){
if(dep_r[x]>=dep_b[x]) return;
if(ok[x]) puts("-1"),exit(0);
chkmax(ans,dep_b[x]);
for(int e=R.hd[x];e;e=R.nxt[e]){
int y=R.to[e];if(y==f) continue;
dep_r[y]=dep_r[x]+1;dfs2(y,x);
}
}
int main(){
scanf("%d%d%d",&n,&x,&y);
for(int i=1,u,v;i<n;i++){
scanf("%d%d",&u,&v);edges_r.pb(mp(u,v));
R.adde(u,v);R.adde(v,u);
}
for(int i=1,u,v;i<n;i++) scanf("%d%d",&u,&v),B.adde(u,v),B.adde(v,u);
dfs1(y,0);for(pii e:edges_r) if(check(e.fi,e.se)) ok[e.fi]=ok[e.se]=1;
dfs2(x,0);printf("%d\n",ans<<1);
return 0;
}

Atcoder Grand Contest 005 E - Sugigma: The Showdown(思维题)的更多相关文章

  1. AtCoder Grand Contest 005

    AtCoder Grand Contest 005 A - STring 翻译 给定一个只包含\(ST\)的字符串,如果出现了连续的\(ST\),就把他删去,然后所有位置前移.问最后剩下的串长. 题解 ...

  2. AtCoder Grand Contest 005 C - Tree Restoring

    题目传送门:https://agc005.contest.atcoder.jp/tasks/agc005_c 题目大意: 给定一个长度为\(N\)的整数序列\(A_i\),问能否构造一个\(N\)个节 ...

  3. AtCoder Grand Contest 005【A栈模拟,B单调栈】

    挖草,AtCoder实在是太吊了~ %%%,目前只A了两题: A题: 就是利用栈模拟一下就好了:S进栈,T的话有S就出栈,然后len减一下就好了: #include <bits/stdc++.h ...

  4. AtCoder Grand Contest 005题解

    传送门 \(A\) 咕咕 const int N=5e5+5; char s[N];int res,n,sum; int main(){ scanf("%s",s+1),res=n ...

  5. AtCoder Grand Contest 032 A - Limited Insertion( 思维)

    Time Limit: 2 sec / Memory Limit: 1024 MB Score : 400400 points Problem Statement Snuke has an empty ...

  6. AtCoder Regular Contest 094 D Worst Case【思维题】

    https://arc094.contest.atcoder.jp/tasks/arc094_b 题意: 在2次超多人的比赛中,你取得的成绩依次为第A名和第B名.一个人的成绩为a和b时,当且仅当ab& ...

  7. AtCoder Grand Contest 012

    AtCoder Grand Contest 012 A - AtCoder Group Contest 翻译 有\(3n\)个人,每一个人有一个强大值(看我的假翻译),每三个人可以分成一组,一组的强大 ...

  8. AtCoder Grand Contest 011

    AtCoder Grand Contest 011 upd:这篇咕了好久,前面几题是三周以前写的... AtCoder Grand Contest 011 A - Airport Bus 翻译 有\( ...

  9. AtCoder Grand Contest 031 简要题解

    AtCoder Grand Contest 031 Atcoder A - Colorful Subsequence description 求\(s\)中本质不同子序列的个数模\(10^9+7\). ...

随机推荐

  1. 寻找写代码感觉(八)之SpringBoot过滤器的使用

    一.什么是过滤器? 过滤器是对数据进行过滤,预处理过程,当我们访问网站时,有时候会发布一些敏感信息,发完以后有的会用*替代,还有就是登陆权限控制等,一个资源,没有经过授权,肯定是不能让用户随便访问的, ...

  2. Scrum Meeting 15

    第15次例会报告 日期:2021年06月09日 会议主要内容概述: 开发工作接近尾声,接下来两天重点放在单元测试.调CSS和增加数据集数量上. 一.进度情况 我们采用日报的形式记录每个人的具体进度,链 ...

  3. 【二食堂】Alpha - Scrum Meeting 1

    Scrum Meeting 1 例会时间:4.10 8:00 - 8:30 进度情况 组员 上周进度 明日任务 李健 1. 在Anaconda3中搭建了python和django的环境issue1. ...

  4. 震惊,hzoi的分差竟然折磨大,活到爆!

    众所周知,hzoi的分差非常"大",那么究竟有多大呢?最近,一位外国小哥开发出了hzoi的分差竟然折磨大,活到爆!的方法,这究竟是怎么一回事呢?快和小编一起来看看吧- 竟然1分就可 ...

  5. NB-IoT的DRX、eDRX、PSM三个模式怎么用?通俗解释,看完就懂!

    面我们讲了不少NB-IOT的应用.软件和硬件设计的变动. (链接在文章末尾). 今天讲讲NB-IoT的三大模式,在各种物联网和智能硬件场景中的使用方法 DRX.eDRx.PSM是什么? DRX虽然叫做 ...

  6. 轻松掌握stm32直流电机驱动与测速

    说实话就现在的市场应用中stm32已经占到了绝对住到的地位,51已经成为过去式,32的功能更加强大,虽然相应的难度有所增加,但是依然阻止不了大家学习32的脚步,不说大话了这些大家都懂要不然也不会学习s ...

  7. 【做题记录】 [HEOI2013]SAO

    P4099 [HEOI2013]SAO 类型:树形 \(\text{DP}\) 这里主要补充一下 \(O(n^3)\) 的 \(\text{DP}\) 优化的过程,基础转移方程推导可以参考其他巨佬的博 ...

  8. Java项目中集成钉钉机器人推送消息提醒

    前言: 项目中有一个需求,当有新订单产生的时候,希望能够及时通知到业务相关人员进行处理,整体考虑了一下,选用了钉钉机器人提醒功能(公司内部主要也是使用钉钉进行通讯). 操作: 主要分为两部分进行处理: ...

  9. H3C 三层交换基于IP限速

    一.背景 目前百度爬虫爬取业务总是按照自己的性能进行抓取客户数据,从来不考虑客户端的网络承受能力,导致客户端网络带宽超出预算范围,因此在客户端方面针对百度的无限制抓取采取相应的策略. 二.解决方案: ...

  10. Language Server for Java™ 1.0 在VS Code上正式发布!

    Nick Zhu form Senior Program Manager, Developer Division at Microsoft 今天,我们很高兴与大家宣布:Language Server ...