美文网首页
tarjan-LCA最近公共祖先离线算法

tarjan-LCA最近公共祖先离线算法

作者: simon_orange | 来源:发表于2016-10-11 08:16 被阅读0次

在一棵树上查询任意两个点的最近公共祖先,或求最短距离的离线算法tarjan,基于dfs遍历和并查集,在查询时倍增直到找到最近公共祖先

//裸题:codevs1036 商务旅行 AC代码如下


#include

#include

#include

#include

using namespace std;

int n,m;

int head[30001],next[60001],to[60001],sum;

int deep[30001];

int f[30001][20];//f[i][j]表示第i个点第2^j个祖先;

int S,T;

int ans_lca,ans;

void dfs(int u)//遍历所有节点;

{

for(int i=head[u];i!=0;i=next[i])

{

if(deep[to[i]]==0)

{

deep[to[i]]=deep[u]+1;

f[to[i]][0]=u;

dfs(to[i]);

}

}

}

void init()

{

for(int i=1;(1<

for(int j=1;j<=n;j++)

if(f[j][i-1]) f[j][i]=f[f[j][i-1]][i-1];

}

int lca(int a,int b)

{

int s=a,e=b;

if(deep[s]

int t=0;

while((1<

for(int i=t;i>=0;i--) if(deep[s]-(1<=deep[e]) s=f[s][i];

if(s==e) return s;

for(int i=t;i>=0;i--)

{

if(f[s][i]&&f[s][i]!=f[e][i])

{

s=f[s][i];

e=f[e][i];

}

}

return f[s][0];

}

int main()

{

scanf("%d",&n);

for(int i=1;i<=n;i++) {f[i][0]=i;deep[i]=0;}

for(int i=1;i

{

int u,v;

scanf("%d%d",&u,&v);

to[++sum]=v;

next[sum]=head[u];

head[u]=sum;

to[++sum]=u;

next[sum]=head[v];

head[v]=sum;

}

dfs(1);

init();

scanf("%d",&m);

S=1;

for(int i=1;i<=m;i++)

{

if(i>1) S=T;

scanf("%d",&T);

ans_lca=lca(S,T);

ans+=deep[S]+deep[T]-2*deep[ans_lca];

}

printf("%d",ans);

}

相关文章

  • tarjan-LCA最近公共祖先离线算法

    在一棵树上查询任意两个点的最近公共祖先,或求最短距离的离线算法tarjan,基于dfs遍历和并查集,在查询时倍增直...

  • Least Common Ancestor

    题目链接:最近公共祖先 树链剖分: Tarjan(离线)算法: 原创模板: RMQ-ST(在线)算法: 题目链接:...

  • LCA(最近公共祖先)算法

    在一棵没有环的树上,每个节点肯定有其父亲节点和祖先节点,而最近公共祖先,就是两个节点在这棵树上深度最大的公共的祖先...

  • 算法—— 最近公共祖先 III

    给一棵二叉树和二叉树中的两个节点,找到这两个节点的最近公共祖先LCA。两个节点的最近公共祖先,是指两个节点的所有父...

  • 小米-基础算法-最近公共祖先

    给一棵二叉树和二叉树中的两个节点,找到这两个节点的最近公共祖先LCA。两个节点的最近公共祖先,是指两个节点的所有父...

  • 最近公共祖先

    LeetCode题目地址 在root为根的二叉树中找A,B的LCA: 如果找到了就返回这个LCA 如果只碰到A,就...

  • 最近公共祖先

    最近公共祖先 简称LCA(Lowest Common Ancestor),所谓LCA,是当给定一个有根树T时,对于...

  • 最近公共祖先

    https://www.lintcode.com/problem/lowest-common-ancestor-o...

  • 最近公共祖先系列

    最近公共祖先I 描述: 给定一棵二叉树,找到两个节点的最近公共父节点 (LCA)。最近公共祖先是两个节点的公共的祖...

  • lintcode 最近公共祖先

    给定一棵二叉树,找到两个节点的最近公共父节点(LCA)。最近公共祖先是两个节点的公共的祖先节点且具有最大深度。样例...

网友评论

      本文标题:tarjan-LCA最近公共祖先离线算法

      本文链接:https://www.haomeiwen.com/subject/pnevyttx.html