并查集练习--hdu1232&&poj1611&&poj2524

并查集模板

//total数组用来计数
//Find找根节点
//Merge 合并两个集合
int fa[N],total[N];
void init(int n){for(int i=0;i<=n;i++)fa[i]=i,total[i]=1;} 
int Find(int x){return fa[x]==x?x:fa[x]=Find(fa[x]);}
void Merge(int a,int b){
    int p1=Find(a),p2=Find(b);
    if(p1!=p2)total[p1]+=total[p2],fa[p2]=p1;
}

POJ1611原题戳这里

代码

#include<iostream>
#include<algorithm>
#include<string.h>
using namespace std;
#define N 30007
int fa[N],total[N];
int n,m,x,y,h;
void init(){for(int i=0;i<=n;i++)fa[i]=i,total[i]=1;} 
int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
void Merge(int a,int b){
    int p1=find(a),p2=find(b);
    if(p1!=p2)total[p1]+=total[p2],fa[p2]=p1;
}
int main(){
	ios::sync_with_stdio(false);cin.tie(0);
	while(cin>>n>>m,n||m){
		init();
		for(int i=0;i<m;i++){
			cin>>x>>y;
			for(int j=1;j<x;j++){
				cin>>h;Merge(y,h);
			}
		}
		cout<<total[find(0)]<<endl;
	}
}

POJ2524

代码

#include<iostream>
#include<algorithm>
#include<string.h>
#include<stdio.h>
#define N 50007
using namespace std;
int fa[N],total[N];
int n,m,x,y,ct,num;
void init(){
	for(int i=0;i<=n;i++)fa[i]=i,total[i]=1;
}
int find(int x){
	return fa[x]==x?x:fa[x]=find(fa[x]);
}
void Merge(int a,int b){
	int p1=find(a),p2=find(b);
	if(p1!=p2)total[p1]+=total[p2],fa[p2]=p1;
}
int main(){
	while(cin>>n>>m,n||m){
		init();
		ct++;
		for(int i=0;i<m;i++){
			cin>>x>>y;Merge(x,y);
		}
		for(int i=1;i<=n;i++)if(find(i)==i)num++;
		printf("Case %d: %d\n",ct,num);num=0;
	}
}

hdu畅通工程1232

#include<stdio.h>
#include<algorithm>
#include<iostream>
#include<vector>
#include<string.h>
#define N 1007
using namespace std;
int n,m,u,v,x,y,num;
int fa[N],total[N];
int init(){
    for(int i=1;i<=n;i++)fa[i]=i;
}
int find(int x){
    return fa[x]==x?x:fa[x]=find(fa[x]);
}
int merge(int x,int y){
    int p1=find(x),p2=find(y);
    if(p1!=p2) fa[p2]=p1;
}
int main(){
    while(cin>>n,n!=0){
        cin>>m;
        init();
        for(int i=0;i<m;i++){
        cin>>x>>y;merge(x,y);
        }
        for(int i=1;i<=n;i++){
            if(find(i)==i)num++;
        }
        cout<<--num<<endl;
        num=0;
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/holly_Z_P_F/article/details/81214736