并查集模板
//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;
}
代码
#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;
}
}
代码
#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;
}
}
#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;
}