1、了解
重点:(初级)掌握find,unite函数
int pra[100001];
int find(int x)
{
return x == par[x] ? x : par[x] = find(par[x]);
}
void unite(int x, int y)
{
x = find(x);
y = find(y);
if (x != y)
{
par[x] = y;
}
}
2、具体用法
在这里插入图片描述
#include <cstdio>
using namespace std;
int par[50001];
int find(int x);
void unite(int x, int y);
int main()
{
int n, m;
int res= 1;
while (scanf("%d%d", &n, &m) != EOF)
{
if (n == 0 && m == 0)
break;
for (int i = 1; i <= n; i++)
{
par[i] = i;
} #初始化.
while (m--)
{
int a, b;
scanf("%d%d", &a, &b);
unite(a, b); #并集。
}
int sum = 0;
for (int i = 1; i <= n; i++)
{
if (par[i] == i)
{
sum++; #统计根的个数。
}
}
printf("Case %d: %d\n", res, sum);
res++;
}
return 0;
}
int find(int x){
return x == par[x] ? x: par[x] = find(par[x]); }
void unite(int x,int y){
x = find(x);
y = find(y);
if (x != y)
{
par[x] = y;
}
}