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为根最深的点 BobAlice

那 我 们 可 以 枚 举 每 个 点 那我们可以枚举每个点

只 要 B o b 到 这 个 点 的 距 离 小 于 A l i c e 到 这 点 的 距 离 就 可 以 过 去 , 取 m a x 只要Bob到这个点的距离小于Alice到这点的距离就可以过去,取max BobAlice,max

#include 
using 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 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:C. Jon Snow and his Favourite Number(构造)
下一篇:C. Jury Marks(map水题)

发表评论

最新留言

网站不错 人气很旺了 加油
[***.192.178.218]2024年04月04日 09时21分47秒