并查集——好朋友

在这里插入图片描述

#include<stdio.h>
const int maxn = 110;
int father[maxn];
bool isRoot[maxn];
void init(int n)
{
    
    
	for(int i = 1; i <= n; i++)
	{
    
    
		father[i] = i;
		isRoot[i] = false;
	}
}
int findFather(int x)
{
    
    
	while(x != father[x])
	{
    
    
		x = father[x];
	}
	return x;
}

void Union(int a, int b)
{
    
    
	int faA = findFather(a);
	int faB = findFather(b);
	if(faA != faB)
	{
    
    
		father[faA] = faB;
	}
}

int main()
{
    
    
   int n, m, a, b;
   scanf("%d%d", &n, &m);
   init(n);
   for(int i = 0; i < m; i++)
   {
    
    
   	  scanf("%d%d", &a, &b);
   	  Union(a, b);
   }
   for(int i = 1; i <= n; i++)
   {
    
    
   	  isRoot[findFather(i)] = true;
   }
   int ans = 0;
   for(int i = 1; i <= n; i++)
   {
    
    
   	   ans += isRoot[i];
   }
   printf("%d\n", ans);
   return 0;
}

猜你喜欢

转载自blog.csdn.net/tian__si/article/details/114321409