水题 求有多少个集合
#include<iostream>
#include<cstdio>
#include<queue>
#include<map>
#include<vector>
#include<cctype>
#include<cstring>
#include<algorithm>
using namespace std;
const int maxn=50000+5;
int p[maxn];
int ans=0;
int getParent(int x){
if(p[x]==x) return x;
int xp=getParent(p[x]);
return p[x]=xp;
}
void merge(int x,int y)
{
int xp=getParent(x);
int yp=getParent(y);
if(xp==yp) return;
ans--;
p[yp]=xp;
}
int main()
{
int n,m,kase=0;
while(cin>>n>>m&&n)
{
for(int i=1;i<=n;i++) p[i]=i;
ans=n;
int x,y;
while(m--){
cin>>x>>y;
merge(x,y);
}
printf("Case %d: %d\n",++kase,ans);
}
return 0;
}

本文介绍了一种使用并查集解决图中集合划分问题的基本算法。通过实例代码演示了如何初始化并查集、查找元素所属集合及合并两个集合的过程。适用于初学者了解并查集的应用场景。
1177

被折叠的 条评论
为什么被折叠?



