HDU 1213 How Many Tables 并查集

Description

今天是Ignatius'的生日,他邀请了很多朋友,现在是晚餐时间,Ignatius'想要知道他至少需要准备多少张桌子。注意,不是所有的朋友都互相认识,并且所有人都不想跟陌生人呆在一起。
一个重要的条件是如果我告诉你A认识B,并且B认识C,那意味着A,B,C互相认识,因此他们可以用一张桌。
例如:如果A认识B, B 认识C,D认识E,因此A,B,C可以用一张桌子,D,E只能用另一张桌子,因此Ignatius'至少需要2张桌子。

Input

输入以T(1<=T<=25)开头,表示测试数据组数。然后接下来有T组测试数据,每组测试数据有两个整数N和M(1<=N,M<=1000)。N表示朋友的数量,编号从1到N。接下来有M行,每行有两个整数A和B(A!=B),那代表A和B互相认识,两组测试数据之间有一个空行。

Output

对于每组测试数据,输出 Ignatius 至少需要多少桌子,不要输出任何空格。

Sample Input

2

5 3

1 2

2 3

4 5

5 1

2 5

Sample Output

2

4

代码区:

#include <iostream>
#include <cstdio>
#include <string.h>

using namespace std;

int bo[1005];//bo为boss简称,该数组是对应老大
int findd(int n)//查找函数
{
    if(bo[n]!=n)   //当n的老大不是自己的时候
        //递归调用findd函数找上一个老大,直到找到老大哥为止
        bo[n]=findd(bo[n]);
    return bo[n];
}

void unionn(int a,int b)
{
    int t1=findd(a);//t1=a的老大
    int t2=findd(b);//t2=b的老大
    if(t1!=t2)
        bo[t2]=t1;//如果两个人的老大不是同一个,说明这是两个黑帮(滑稽
        //将其中一个黑帮的老大变成另一个黑帮的小弟
        //成功合并两个黑帮
}
int main()
{
    int T,n,m=0;
    int p1,p2=0;
    cin >> T;//输入测试数据的组数
    while(T--)
    {
        int c=0;
        cin >> n >> m;
        for(int i=1;i<=n;i++)
            {
                bo[i]=i;//此处将每个人的老大设定为自己,进行初始化
            }
        while(m--)
        {
            cin >> p1 >> p2;
            unionn(p1,p2);//d调用unionn函数将两个人合并成一个组织
        }
        for(int i=1;i<=n;i++)//对每个人进行判断
            if(findd(i)==i)//如果他自己就是老大,那么说明这是一个组织(因为不是老大的小弟都已经并到别的组织里去了
                c++;//组织个数计数器
        cout << c << endl;
    }
    //我将朋友关系比喻成黑帮组织,可通过组织的个数来得出一共需要的椅子数量
    return 0;
}

新手上路,有错请指正

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Khalil三省

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值