您的位置:首页 > 其它

hdu-1213-How Many Tables

2017-07-26 16:33 381 查看
题目传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1213

并查集算法,推荐博客(点击“博客”两字)。

推荐类似题目:

 poj-1258-Agri-Net 
hdu-1232-畅通工程
hdu-1863-畅通工程

#include <iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<stack>
#include<queue>

using namespace std;

int a[1005];

int bing(int x)
{
if(a[x]==x) return x;

a[x]=bing(a[x]);
return a[x];
}
int main()
{
int t;
cin>>t;
while(t--)
{
int m,n;;
cin>>m>>n;
for(int i=1; i<=m; i++)
{
a[i]=i;
}

for(int i=1; i<=n; i++)
{
int x,y;
cin>>x>>y;
int xx=bing(x),yy=bing(y);
if(xx!=yy)
{
a[yy]=xx;
}
}
int ans=0;
for(int i=1; i<=m; i++)
{
if(a[i]==i) ans++;
}
cout<<ans<<endl;
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: