POJ 1330 Nearest Common Ancestors

原创 2015年11月20日 00:18:37
模板题。。。。
#include <iostream>
#include <vector>
#include <cstdio>

using namespace std;

const int MAX=10005;
vector<int> G[MAX];
int depth[MAX];
int parent[MAX];
int root, n;
bool vis[MAX];

void dfs(int v, int p, int d)
{
  parent[v] = p;
  depth[v] = d;
  for (int i=0;i<G[v].size(); i++)
  {
    if (G[v][i] != p)
      dfs(G[v][i], v, d+1);
  }
}

void init()
{
  for(int i = 1; i <= n; i++)
    if(!vis[i])
      dfs(i, -1, 0);
}

int lca(int u, int v)
{
  while (depth[u] > depth[v])
    u = parent[u];
  while (depth[v] > depth[u])
    v = parent[v];
  while (u != v)
  {
    u = parent[u];
    v = parent[v];
  }
  return u;
}

int main()
{
  std::ios::sync_with_stdio(false);
  int T;
  cin >> T;
  while (T--)
  {
    cin >>  n;
    for (int i = 1; i <= n; i++)
      G[i].clear();
    for (int i = 0; i < n-1; i++)
    {
      int t1,t2;
      cin >> t1 >> t2;
      G[t1].push_back(t2);
      vis[t2] = true;
    }
    int f_u, f_v;
    cin >> f_u >> f_v;
    //root = 1;
    //dfs(1, -1, 0);
    init();
    //cout << depth[f_v] << depth[f_u] << endl;
    cout << lca(f_u,f_v) << endl;
  }
  return 0;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

POJ1330 Nearest Common Ancestors(最近公共祖先LCA 并查集+DFS)

Nearest Common Ancestors Time Limit: 1000MS   Memory Limit: 10000K Total Submissions...

poj 1330 Nearest Common Ancestors(简单的树初探)

Nearest Common Ancestors Time Limit: 1000MS   Memory Limit: 10000K Total Submiss...

poj1330 Nearest Common Ancestors

题目链接:..G20过了再补 题目大意:求最近公共祖先...水.. 题解:倍增LCA/树剖 就是练模版的题...话说看了一下,我的树剖比倍增还快了那么一丢丢.. 注意:不是无根树啊23...

poj1330 Nearest Common Ancestors(LCA离线算法)

http://poj.org/problem?id=1330 题意:给你n个节点和n-1个关系,通过关系建起一棵树,然后给你两个节点,求他们的最小公共祖先。 ps:这里的Tarjan离线算法貌似...

LCA-倍增思想 POJ1330 Nearest Common Ancestors

LCA 倍增
  • ivy_uu
  • ivy_uu
  • 2016年07月07日 23:11
  • 165

poj 1330 Nearest Common Ancestors(LCA模板)

http://poj.org/problem?id=1330 题意:给出两个点,求出这两个点最近的公共祖先。 求LCA的模板题。 大致思路就是访问到某个节点时,先将它自己加入集合中,然后递归访问它的子...

poj 1330 Nearest Common Ancestors 朴素LCA算法

Nearest Common AncestorsTime Limit: 1000MS Memory Limit: 10000KTotal Submissions: 9213 Accepted: 488...

[LCA模板]POJ1330 Nearest Common Ancestors

题目链接 : http://poj.org/problem?id=1330 题目大意 :求一颗树的LCA 代码: /* POJ 1330 给定一棵树 边的形式为a是b父亲 求LC...

【LCA】 POJ 1330 Nearest Common Ancestors

LCA模板题。。用一下tarjan的离线suan

poj 1330 Nearest Common Ancestors(最近公共祖先(LCA))

Description A rooted tree is a well-known data structure in computer science and engineering. An ex...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:POJ 1330 Nearest Common Ancestors
举报原因:
原因补充:

(最多只允许输入30个字)