8 10 0 1 1 2 1 3 2 4 3 4 0 5 5 6 6 7 3 6 4 7
3
#include<stdio.h>
const int N = 1015;
int fath[N],n;
void init()
{
for(int i =0;i<=n;i++)
fath[i]=i;
}
int findfath(int x)
{
if(x==fath[x])
return fath[x];
fath[x]=findfath(fath[x]);
return fath[x];
}
int setfath(int x,int y)
{
x=findfath(x);
y=findfath(y);
if(x==y)
return 1;
fath[x]= y;
return 0;
}
int main()
{
int x,y,m,ans;
while(scanf("%d%d",&n,&m)>0)
{
init();
ans=0;
while(m--)
{
scanf("%d%d",&x,&y);
ans+=setfath(x,y);
}
printf("%d\n",ans);
}
}
HDU2120Ice_cream's world I(基础并查集)
原文地址:http://blog.csdn.net/u010372095/article/details/44043481