HDU1232 畅通工程,并查集

这里要补充一些知识点,并查集三操作

1.找到父节点递归写法
int Findf(int x)
{
if(father[x]!=x)
father[x]=Findf(father[x]);
return father[x];
}
另一种写法
int Findf(int x)
{
int r=x;
while(father[r]!=r)
r=father[r];
return r;
}
2.融合两个集合
void union(int x, int y)
{
int u, v;
u=Findf(x);
v=Findf(y);
if(u!=v)
father[u]=v;
}
简便写法
void union(int x, int y)
{
father[Findf(x)]=Findf(y);
}
3.判断a和b是否在同一个集合
void judge(int a, int b)
{
return Findf(a)==Findf(b);
}

#include<iostream>
#include<stdio.h>
#include<string.h>
using namespace std;
const int N=1010;
int father[N];
int Find(int x);
int main()
{
int town, rode, u, v, ans;
while(scanf("%d", &town), town)
{
ans=0;
scanf("%d", &rode);
for(int i=0; i<=town; i++)
{
father[i]=i;
}
for(int i=1; i<=rode; i++)
{
scanf("%d%d", &u, &v);
int ru=Find(u);
int rv=Find(v);
if(ru!=rv)
father[ru]=rv;
}
for(int i=1; i<=town; i++)
{
if(father[i]==i)
ans++;
}
printf("%d ", ans-1);
}
return 0;
}
int Find(int x)
{
if(father[x]!=x)
father[x]=Find(father[x]);
return father[x];
}

原文地址:https://www.cnblogs.com/wazqWAZQ1/p/4667537.html