标签:
解题思路:给出n对点的关系,求构成多少个环,如果对于点x和点y,它们本身就有一堵墙,即为它们本身就相连,如果find(x)=find(y),说明它们的根节点相同,它们之间肯定有直接或间接的相连,即形成环
样例的示意图
共3个环
Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 642 Accepted Submission(s): 371
#include<stdio.h> #include<string.h> int pre[10005],a[10005]; int find( int root) { if(root!=pre[root]) pre[root]=find(pre[root]); return pre[root]; } void unionroot( int root1,int root2) { int x,y; x=find(root1); y=find(root2); if(x!=y) pre[x]=y; } int main() { int root1,root2,x,y,i,n,m,tmp; while(scanf("%d %d",&n,&m)!=EOF) { tmp=0; for(i=0;i<=10005;i++) pre[i]=i; while(m--) { scanf("%d %d",&root1,&root2); x=find(root1); y=find(root2); if(x==y) tmp++; unionroot(x,y); } printf("%d\n",tmp); } }
HDU 2120 Ice_cream's world I【并查集】
标签:
原文地址:http://www.cnblogs.com/wuyuewoniu/p/4202585.html