传送门:HDU 1213
基础并查集。
#include <iostream>
#include <cstdio>
#define MAX 1005
using namespace std;
int father[MAX];
int Find(int x)
{
if(x==father[x])
return x;
return Find(father[x]);
}
void Union(int x,int y)
{
int xx=Find(x);
int yy=Find(y);
father[xx]=yy;
}
int main()
{
int T,n,m,x,y,i,Count;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
for(i=1;i<=n;i++)
father[i]=i;
for(i=1;i<=m;i++)
{
scanf("%d%d",&x,&y);
Union(x,y);
}
for(i=1,Count=0;i<=n;i++)
if(father[i]==i)
Count++;
printf("%d\n",Count);
}
return 0;
}
本文介绍了一个基础并查集的应用实例,通过解决HDU1213问题来演示并查集的基本操作,包括查找和合并两个核心过程。
&spm=1001.2101.3001.5002&articleId=40041527&d=1&t=3&u=c2347318c08f4ff9877013f48e34b4b1)
1429

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



