LCA。注意细节。

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define maxv 500500
#define maxe 1005000
using namespace std;
int n,m,x,y,z,g[maxv],nume=,anc[maxv][],dis[maxv];
struct edge
{
int v,nxt;
}e[maxe];
void addedge(int u,int v)
{
e[++nume].v=v;
e[nume].nxt=g[u];
g[u]=nume;
}
void dfs(int x)
{
for (int ee=;ee<=;ee++)
anc[x][ee]=anc[anc[x][ee-]][ee-];
for (int i=g[x];i;i=e[i].nxt)
{
int v=e[i].v;
if (v!=anc[x][])
{
anc[v][]=x;dis[v]=dis[x]+;
dfs(v);
}
}
}
int lca(int x,int y)
{
if (dis[x]<dis[y]) swap(x,y);
for (int e=;e>=;e--)
{
if ((dis[anc[x][e]]>=dis[y]) && (anc[x][e]!=))
x=anc[x][e];
}
if (x==y) return x;
for (int ee=;ee>=;ee--)
{
if (anc[x][ee]!=anc[y][ee])
{
x=anc[x][ee];
y=anc[y][ee];
}
}
return anc[x][];
}
int get_dis(int x,int y)
{
int k=lca(x,y);
return dis[x]+dis[y]-*dis[k];
}
int main()
{
scanf("%d%d",&n,&m);
for (int i=;i<=n-;i++)
{
scanf("%d%d",&x,&y);
addedge(x,y);
addedge(y,x);
}
dfs();
for (int i=;i<=m;i++)
{
scanf("%d%d%d",&x,&y,&z);
int t1,t2,t3;
t1=lca(x,y);t2=lca(x,z);t3=lca(y,z);
int ans1,ans2=;
if (t1==t2) ans1=t3;
else if (t1==t3) ans1=t2;
else ans1=t1;
ans2=get_dis(x,ans1)+get_dis(y,ans1)+get_dis(z,ans1);
printf("%d %d\n",ans1,ans2);
}
return ;
}

最新文章

  1. CentOS 7.x设置自定义开机启动,添加自定义系统服务
  2. 微信 {&quot;errcode&quot;:48001,&quot;errmsg&quot;:&quot;api unauthorized, hints: [ req_id: 1QoCla0699ns81 ]&quot;}
  3. PostgreSQL表空间、数据库、模式、表、用户/角色之间的关系
  4. JS-页面操作
  5. ubifs物理存储
  6. 关于SQL Server中分区表的文件与文件组的删除(转)
  7. IIS 分析器错误消息: 未能加载类型“_Default”
  8. phpStorm 使用技巧大集合
  9. wift - 使用UIScreen类获取屏幕大小尺寸
  10. 错误号码2003 Can&#39;t connect to MySQL server &#39;localhost&#39; (0)
  11. 如何从官网下载 Google Chrome 离线安装包
  12. PB中datewindow单双行显示不同颜色
  13. Day2作业及默写
  14. 【转】python 修改os环境变量
  15. HDU 5810 Balls and Boxes 数学
  16. UVa 10766 Organising the Organisation(矩阵树定理)
  17. Linux 软件 安装到 /usr,/usr/local/ 还是 /opt 目录
  18. SQL Server DB Link相关
  19. Xcode官方xip直接离线下载地址(更新到Xcode 9.4.1)
  20. jQuery 性能优化技巧

热门文章

  1. 解决JS文件页面加载时的阻塞
  2. ZOJ3724 Delivery(树状数组??)
  3. POJ 2081
  4. login shell 和 non-login shell 的区别
  5. HDU 2602 Bone Collector (简单01背包)
  6. WCF分布式开发步步为赢(7):WCF数据契约与序列化
  7. nodejs的require模块及路径
  8. iOS开发swift--函数
  9. JavaPersistenceWithHibernate第二版笔记-第四章-Mapping persistent classes-001区分entities and value types
  10. 关于J-LINK升级最新固件后无法连上的一点分析