Chinaunix首页 | 论坛 | 博客
  • 博客访问: 38547
  • 博文数量: 64
  • 博客积分: 2640
  • 博客等级: 少校
  • 技术积分: 670
  • 用 户 组: 普通用户
  • 注册时间: 2010-01-26 13:15
文章分类
文章存档

2010年(64)

我的朋友
最近访客

分类: C/C++

2010-01-26 14:08:56

2009-05-12 10:45

#include<iostream>
using namespace std;

int father[5010],rank[5010];
int n,m,p;

void Init();
void Judge(int x,int y);
void Union(int x,int y);

int main(void){
    int i,a,b;
   
    cin>>n>>m>>p;
    Init();
    for(i=0;i<m;i++){
        cin>>a>>b;
        Union(a,b);
    }
   
    for(i=0;i<p;i++){
        cin>>a>>b;
        Judge(a,b);
    }
   
    system("pause");
    return 0;
}

void Init(){
     for(int i=1;i<=n;i++){
         rank[i] = 0;
         father[i] = i;
     }
}
    
void Judge(int x,int y){
     while(x!=father[x]) x = father[x];
     while(y!=father[y]) y = father[y];
    
     if(x==y) cout<<"Yes"<<endl;
     else cout<<"No"<<endl;
}
    
void Union(int x,int y){
     while(x!=father[x]) x = father[x];
     while(y!=father[y]) y = father[y];
    
     if(rank[x]>rank[y]) father[y] = x;
     else if(rank[y]>rank[x]) father[x] = y;
     else{
         rank[x]++;
         father[y] = x;
     }
}
        


阅读(259) | 评论(0) | 转发(0) |
0

上一篇:表达式求值

下一篇:比较纯的spfa

给主人留下些什么吧!~~