C. The Tag Game(树的深度)
发布日期:2021-06-30 10:18:07
浏览次数:2
分类:技术文章
本文共 949 字,大约阅读时间需要 3 分钟。
我还是想复杂了啊
跑 出 A l i c e 到 每 个 点 的 距 离 , 跑 出 B o b 到 每 个 点 的 距 离 跑出Alice到每个点的距离,跑出Bob到每个点的距离 跑出Alice到每个点的距离,跑出Bob到每个点的距离
那 么 B o b 想 跑 的 尽 可 能 远 也 就 是 以 A l i c e 为 根 最 深 的 点 那么Bob想跑的尽可能远也就是以Alice为根最深的点 那么Bob想跑的尽可能远也就是以Alice为根最深的点
那 我 们 可 以 枚 举 每 个 点 那我们可以枚举每个点 那我们可以枚举每个点
只 要 B o b 到 这 个 点 的 距 离 小 于 A l i c e 到 这 点 的 距 离 就 可 以 过 去 , 取 m a x 只要Bob到这个点的距离小于Alice到这点的距离就可以过去,取max 只要Bob到这个点的距离小于Alice到这点的距离就可以过去,取max
#includeusing namespace std;const int maxn=2e5+10;int n,b;struct p{ int to,nxt;}d[maxn<<1]; int cnt=1,head[maxn<<1];void add(int u,int v){ d[cnt].to=v,d[cnt].nxt=head[u],head[u]=cnt++;}int dis1[maxn],dis2[maxn];void dfs(int u,int fa,int s,int dis[]){ dis[u]=s; for(int i=head[u];i;i=d[i].nxt) { int v=d[i].to; if( v==fa ) continue; dfs(v,u,s+1,dis); }}int main(){ cin >> n >> b; for(int i=1;i > l >> r; add(l,r);add(r,l); } dfs(1,0,0,dis1); dfs(b,0,0,dis2); int ans=0;//默认是a到b的距离 for(int i=1;i<=n;i++) if( dis2[i]
转载地址:https://issue-is-vegetable.blog.csdn.net/article/details/107247508 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
网站不错 人气很旺了 加油
[***.192.178.218]2024年04月04日 09时21分47秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
POJ-2418 Hardwood Species(Trie树)(map)
2019-04-30
HDU-4300 Clairewd’s message + 4333(扩展KMP)
2019-04-30
HDU 1592 Half of and a Half(高精度)
2019-04-30
POJ-3304 Segments(计算几何)
2019-04-30
UVA-11538 Chess Queen(数学)
2019-04-30
UVA-11401 Triangle Counting(数学优化)
2019-04-30
UVA 11806 Cheerleaders(容斥原理)(组合数)
2019-04-30
Codeforces Round #369 (Div. 2)
2019-04-30
UVA 11426 GCD - Extreme (II)(欧拉函数)
2019-04-30
HDU-2838 Cow Sorting(树状数组)
2019-04-30
POJ-2299 Ultra-QuickSort(树状数组)(离散化)
2019-04-30
POJ-1655 Balancing Act(树的重心)
2019-04-30
POJ-3140 Contestants Division(树dp)
2019-04-30
2017 ACM-ICPC 亚洲区(西安赛区)网络赛 C. Sum
2019-04-30
HDU-6214 Smallest Minimum Cut(最大流)
2019-04-30
Windows安装Scrapy库
2019-04-30