您的位置:首页 > 其它

╮(╯▽╰)╭ 数蚂蚁

2015-07-31 22:36 253 查看

╮(╯▽╰)╭ 数蚂蚁

TimeLimit: 2000/1000 MS (Java/Others) MenoryLimit: 65536/32768 K (Java/Others)

64-bit integer IO format:%I64d

Problem Description
Lh Boy无聊的时候很喜欢数蚂蚁,而且,还给每一只小蚂蚁编号,通过他长期的观察和记录,发现编号为i的蚂蚁会和编号为j的蚂蚁在一起。
现在问题来了,他现在只有他的那本记录本,然而,他想要知道,他所观察的蚂蚁中,有多少堆蚁群。没有记录的编号则作为独自一个一堆。

Input
第一行输入一个整数T,表示有T(1<=T<=25)组测试案例。每一组测试案例,先输入两个整数N和M,分别表示蚂蚁的总数(编号分别为1~N)和记录的条数(1<=N,M<=1000)。紧接着有M行,每一行输入两个数字,a b,表示编号a和编号b的蚂蚁在同一堆里面。在每组测试案例之间都会输入一行空行。

Output
对于每组测试案例,在一行中输出答案。

SampleInput

2
5 3
1 2
2 3
4 5

5 1
2 5


SampleOutput

2
4
解法:就是基础的并查集。。。
代码:


#include <iostream>
#include <string.h>
#include <stdio.h>
#include <map>
using namespace std;
int ID[10086];
void Cread(int N)
{
for(int i=0;i<=N;i++)ID[i]=i;
}
int Find(int x)
{
int tmp;
if(ID[x]!=x)tmp=Find(ID[x]);
else tmp=x;
ID[x]=tmp;
return tmp;
}
int main()
{
int N,M,i,j,k,T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&N,&M);
Cread(N);
int a,b;
int sign=0;
for(i=0;i<M;i++)
{
scanf("%d%d",&a,&b);
a=Find(a);
b=Find(b);
if(a!=b)
{
sign++;
ID[a]=b;
}
}
printf("%d\n",N-sign);
}
return 0;
}


View Code

                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: