关于Tarjan(3)——离线LCA
LCA(最近公共祖先),指对于一棵树上任意两个节点往上走最早都能到达的节点。
求LCA有两种方法,一种是倍增,另一种则是Tarjan。。。。。。。。
Tarjan巧妙利用并查集的思想;
这里的Tarjan是离线算法
先Tarjan下去;
首先有fa[NUM]=num;
回溯时将子节点的fa变为num
如果对于num的询问中另一个点已经访问;
那他们的LCA为另一个点的find(fa)
原因:&&一个点与另一个点都位于以他们的LCA为根节点的子树中;
如果没有相关点的信息,只说明在该节点的上方,故回溯时把fa的变为父节点;
这里的find是并查集中的代表元素。。。。。
再处理各种询问
另外,两点距离为dis[x]+dis[y]-2*dis[LCA(x,y)];
附上原题代码及地址http://codevs.cn/problem/2370/
#include<iostream>
#include<cstdlib>
#include<cstdio>
#define N 50001
using namespace std;
struct data{
int to,nxt,ans;
}ask[75001*2];
struct node{
int nxt,to,w;
}edge[N*2+1];
int tot,tot1,n,m;
bool vis[N];
int dis[N],fa[N];
int head[N],head1[75001*2];
int find(int x){if(fa[x]!=x)fa[x]=find(fa[x]);return fa[x];}
void add1(int x,int y){
ask[++tot1].nxt=head1[x];
ask[tot1].to=y;
head1[x]=tot1;
}
void dfs(int num,int hehe){
dis[num]=hehe;
for(int i=head[num];i;i=edge[i].nxt)
if(!dis[edge[i].to]&&edge[i].to){
int to=edge[i].to;
dfs(to,hehe+edge[i].w);
}
}
void Tarjan_LCA_haha(int t){
vis[t]=true;
fa[t]=t;
for(int i=head[t];i;i=edge[i].nxt)
if(!fa[edge[i].to]&&edge[i].to){
int to=edge[i].to;
Tarjan_LCA_haha(to);
fa[to]=t;
}
for(int i=head1[t];i;i=ask[i].nxt)
if(vis[ask[i].to])
ask[i].ans=dis[ask[i].to]+dis[t]-2*dis[find(ask[i].to)];
}
int main(){
scanf("%d",&n);
for(int i=1;i<n;++i){
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
edge[++tot].nxt=head[a];
head[a]=tot;
edge[tot].w=c;
edge[tot].to=b;
edge[++tot].nxt=head[b];
head[b]=tot;
edge[tot].w=c;
edge[tot].to=a;
}
scanf("%d",&m);
for(int i=1;i<=m;++i){
int a,b;
scanf("%d%d",&a,&b);
add1(a,b);
add1(b,a);
}
dfs(0,0);
Tarjan_LCA_haha(0);
for(int i=1;i<=2*m;i+=2)
if(ask[i].ans)printf("%d\n",ask[i].ans);
else printf("%d\n",ask[i+1].ans);
return 0;
}
关于Tarjan(3)——离线LCA的更多相关文章
- 【图论】tarjan的离线LCA算法
百度百科 Definition&Solution 对于求树上\(u\)和\(v\)两点的LCA,使用在线倍增可以做到\(O(nlogn)\)的复杂度.在NOIP这种毒瘤卡常比赛中,为了代码的效 ...
- hihoCoder #1067 : 最近公共祖先·二 [ 离线LCA tarjan ]
传送门: #1067 : 最近公共祖先·二 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 上上回说到,小Hi和小Ho用非常拙劣——或者说粗糙的手段山寨出了一个神奇的网站 ...
- poj1470 Closest Common Ancestors [ 离线LCA tarjan ]
传送门 Closest Common Ancestors Time Limit: 2000MS Memory Limit: 10000K Total Submissions: 14915 Ac ...
- Tarjan算法离线 求 LCA(最近公共祖先)
本文是网络资料整理或部分转载或部分原创,参考文章如下: https://www.cnblogs.com/JVxie/p/4854719.html http://blog.csdn.net/ywcpig ...
- 【BFS】【并查集】【Tarjan】【LCA】Gym - 101173H - Hangar Hurdles
给你一张地图,给你q次询问,每次问你从A点到B点,最大能移动多大的箱子. 把每个点所能容纳的最大箱子求出来(BFS,八连通,一开始将所有边界点和障碍点入队).然后从大到小排序.然后用并查集将相邻(四联 ...
- tarjan算法求LCA
tarjan算法求LCA LCA(Least Common Ancestors)的意思是最近公共祖先,即在一棵树中,找出两节点最近的公共祖先. 这里我们使用tarjan算法离线算法解决这个问题. 离线 ...
- HDU 2586 How far away ? 离线lca模板题
How far away ? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- HDU 5044 离线LCA算法
昨天写了HDU 3966 ,本来这道题是很好解得,结果我想用离线LCA 耍一把,结果发现离线LCA 没理解透,错了好多遍,终得AC ,这题比起 HDU 3966要简单,因为他不用动态查询.但是我还是错 ...
- SPOJ 10628 Count on a tree(Tarjan离线LCA+主席树求树上第K小)
COT - Count on a tree #tree You are given a tree with N nodes.The tree nodes are numbered from 1 to ...
随机推荐
- POI-处理大Excel文件(xls)
最近需要处理一个比较大的excel文件,但是poi在处理文件时会抛出OOM导致程序崩溃,查看官方文档看到可以以流式的方式读取excel避免读取大文件时的OOM.本文主要记述xls的处理. 环境模拟 先 ...
- java精度计算代码,指定精确小数位
java代码: public class App2 { public static void main(String[] args) { String val = checkNumber(" ...
- 简学Python第一章__进入PY的世界
#cnblogs_post_body h2 { background: linear-gradient(to bottom, #18c0ff 0%,#0c7eff 100%); color: #fff ...
- vue2重写饿了么
构建 vue有自己的脚手架构建工具vue-cli,使用起来非常方便,使用webpack来集成各种开发便捷工具,比如: 代码热更新,修改代码之后网页无刷新改变,对前端开发来说非常的方便 PostCss, ...
- 基于canvas的二维码邀请函生成插件
去年是最忙碌的一年,实在没时间写博客了,看着互联网行业中一个又一个人的倒下,奉劝大家,健康要放在首位,保重身体.好了,言归正传,这是17年的第一篇博文,话说这天又是产品同学跑过来问我说:hi,lenn ...
- java-6数组
一. 请编写一个程序将一个整数转换为汉字读法字符串.比如"1123"转换为"一千一百二十三".更进一步,能否将数字表示的金额改为"汉字表达?比如将&q ...
- 运行gpg --gen-key生成key时出现卡住的问题
背景 在搭建Ubuntu16.04的本地apt源时,需要运行"gpg --gen-key"命令,但是在执行该命令时,出现了:"Not enough random byte ...
- 图片转换PDF
组件在我的文件里,需要的可以找找. public partial class MainForm : Form { private string srcFile, destFile; bool succ ...
- 一次MySQL死锁问题解决
一次MySQL死锁问题解决 一.环境 CentOS, MySQL 5.6.21-70, JPA 问题场景:系统有定时批量更新数据状态操作,每次更新上千条记录,表中总记录数约为500W左右. 二.错误日 ...
- 【PHP系列】PHP组件详解
缘起 枫爷之前做过几年的PHP的研发,大部分都是在开源框架的引导下,编写代码.现在依然,本能的会去让我使用某个PHP框架开发PHP应用,也是因为懒吧,没有好好的去研究研究除了框架之外的一些东西. 今天 ...