BZOJ 1787 紧急集合
2024-10-14 00:16:04
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 ;
}
最新文章
- CentOS 7.x设置自定义开机启动,添加自定义系统服务
- 微信 {";errcode";:48001,";errmsg";:";api unauthorized, hints: [ req_id: 1QoCla0699ns81 ]";}
- PostgreSQL表空间、数据库、模式、表、用户/角色之间的关系
- JS-页面操作
- ubifs物理存储
- 关于SQL Server中分区表的文件与文件组的删除(转)
- IIS 分析器错误消息: 未能加载类型“_Default”
- phpStorm 使用技巧大集合
- wift - 使用UIScreen类获取屏幕大小尺寸
- 错误号码2003 Can&#39;t connect to MySQL server &#39;localhost&#39; (0)
- 如何从官网下载 Google Chrome 离线安装包
- PB中datewindow单双行显示不同颜色
- Day2作业及默写
- 【转】python 修改os环境变量
- HDU 5810 Balls and Boxes 数学
- UVa 10766 Organising the Organisation(矩阵树定理)
- Linux 软件 安装到 /usr,/usr/local/ 还是 /opt 目录
- SQL Server DB Link相关
- Xcode官方xip直接离线下载地址(更新到Xcode 9.4.1)
- jQuery 性能优化技巧
热门文章
- 解决JS文件页面加载时的阻塞
- ZOJ3724 Delivery(树状数组??)
- POJ 2081
- login shell 和 non-login shell 的区别
- HDU 2602 Bone Collector (简单01背包)
- WCF分布式开发步步为赢(7):WCF数据契约与序列化
- nodejs的require模块及路径
- iOS开发swift--函数
- JavaPersistenceWithHibernate第二版笔记-第四章-Mapping persistent classes-001区分entities and value types
- 关于J-LINK升级最新固件后无法连上的一点分析