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;
}

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

LCA问题的Tarjan算法(POJ1330)

LCA问题(Least Common Ancestors,最近公共祖先问题),是指给定一棵有根树T,给出若干个查询LCA(u, v)(通常查询数量较大),每次求树T中两个顶点u和v的最近公共祖先,即找...
  • hy1405430407
  • hy1405430407
  • 2015年09月02日 17:53
  • 684

POJ1330 最近公共祖先

Nearest Common Ancestors Time Limit: 1000MS   Memory Limit: 10000K Total Submissions...
  • zy704599894
  • zy704599894
  • 2016年08月12日 17:56
  • 1466

Nearest Common Ancestors(最近公共祖先)

Nearest Common Ancestors Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 14650   ...
  • u010527492
  • u010527492
  • 2013年08月04日 23:35
  • 567

POJ1330(LCA离线和在线)

Nearest Common Ancestors Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 28271 ...
  • qq_33183401
  • qq_33183401
  • 2017年04月18日 23:03
  • 360

POJ 1330 Nearest Common Ancestors 最近公共祖先模板/在线/离线

题意:求树上两个节点的最近公共祖先 算法一:tarjan LCA(u) {   Make-Set(u)   ancestor[Find-Set(u)]=u  //设置u所在集合...
  • Tsaid
  • Tsaid
  • 2013年05月28日 21:53
  • 1423

POJ, 1330 Nearest Common Ancestors(找出两个节点最近的公共节点——BFS)

Problem B : Nearest Common Ancestors From:POJ, 1330 Description A rooted tree is a well-known...
  • Hush_lei
  • Hush_lei
  • 2014年07月30日 15:30
  • 525

(用树的遍历求解层次性问题8.1.1)POJ 1330 Nearest Common Ancestors(求解最近共同祖先)

/* * POJ_1330.cpp * * Created on: 2013年11月4日 * Author: Administrator */ #include #inclu...
  • caihongshijie6
  • caihongshijie6
  • 2013年11月05日 14:07
  • 1050

[POJ3415]Common Substrings(后缀数组+单调栈)

题目描述传送门 题意:给定两个字符串 A 和 B ,求长度不小于 k 的公共子串的个数(可以相同)。题解首先把一个串接在另一个串的后面,中间放一个没出现过的字符。 由于每一个子串都是某一个后缀的前...
  • Clove_unique
  • Clove_unique
  • 2016年12月26日 21:20
  • 628

【POJ】3415 Common Substrings 【后缀数组+单调栈】

传送门:【POJ】3415 Common Substrings 题目分析: 题目要求的实质是计算 A 的所有后缀和 B 的所有后缀之间的最长公共前缀的长度,然后把最长公共前缀长度不小于...
  • u013368721
  • u013368721
  • 2014年12月10日 21:43
  • 975

POJ 1470 Closest Common Ancestors 采用树结构的非线性表编程

A - Closest Common Ancestors(8.4.9) Time Limit:2000MS     Memory Limit:10000KB     64bit IO Format:%...
  • zp___waj
  • zp___waj
  • 2015年08月25日 20:11
  • 497
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:POJ 1330 Nearest Common Ancestors
举报原因:
原因补充:

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