您的位置:首页 > 其它

poj1611 the suspects(并查集)

2017-09-04 12:29 357 查看
并查集裸题。

#include<cstdio>
#define N 30005
int fa
,n,m;
int find(int x){
return fa[x]==x?x:fa[x]=find(fa[x]);
}
int main(){
//  freopen("a.in","r",stdin);
while(1){
int ans=1;
scanf("%d%d",&n,&m);
if(n==0&&m==0) break;
for(int i=0;i<n;++i) fa[i]=i;
while(m--){
int k,a,b;
scanf("%d%d",&k,&a);
for(int i=1;i<k;++i){
scanf("%d",&b);
int xx=find(a),yy=find(b);
if(xx!=yy) f[yy]=xx;
}
}
for(int i=1;i<n;++i)
if(find(i)==find(0)) ans++;
printf("%d\n",ans);
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: