LCA—-最近公用祖先

來源:互聯網
上載者:User

推薦部落格:http://kmplayer.iteye.com/blog/604518

poj  1330

原始碼:

#include <stdio.h>#include <vector>#define MAXN 10005using namespace  std;vector<int>tree[MAXN];vector<int>query[MAXN];int n,q;int  s,t,cas;int f[MAXN],visit[MAXN];   //MAXN為節點編號的最大值int degree[MAXN];  //記錄入度int ancestor[MAXN];  //記錄某一個並查集的祖先int r[MAXN];  //深度void Init(){    for(int i=1;i<=n;i++)    {        r[i]=1;        visit[i]=0;        f[i]=i;        ancestor[i]=i;        degree[i]=0;        tree[i].clear();        query[i].clear();    }}int find(int x){    if(x==f[x])  return x;    else    {        f[x]=find(f[x]);        return f[x];    }}int Uion(int x,int y)   //合并成功返回1,合并不成功返回0{    int a=find(x);    int b=find(y);    if(a==b)  return 0;    if(r[a]>r[b])    {        r[a]+=r[b];        f[b]=a;    }    else    {        r[b]+=r[a];        f[a]=b;    }    return 1;}void lca(int u){    for(int i=0;i<tree[u].size();i++)    {        lca(tree[u][i]);        Uion(tree[u][i],u);        ancestor[find(u)]=u;    }    visit[u]=1;    for(int i=0;i<query[u].size();i++)    {        if(visit[query[u][i]]==1)        {            printf("%d\n",ancestor[find(query[u][i])]);        }    }}int main(){    freopen("D:\\a.txt","r",stdin);    scanf("%d",&cas);    while(cas--){    scanf("%d",&n);    Init();    for(int i=1;i<n;i++)    {        scanf("%d %d",&s,&t);       //s[i]是父節點,t[i]是子節點        tree[s].push_back(t);        degree[t]++;    }    //scanf("%d",&q);   // for(int i=0;i<q;i++)   // {        scanf("%d %d",&s,&t);  //查詢s,t的最近公用祖先        query[s].push_back(t);        query[t].push_back(s);  //  }    for(int i=1;i<=n;i++)    {      if(degree[i]==0)      {          lca(i);          break;      }    }  }    return 0;}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.