题目描述
有n个人,编号为1,2,……n,另外还知道存在K个关系。一个关系的表达为二元组(α,β)形式,表示α,β为同一家庭的成员。
当n,k和k个关系给出之后,求出其***有多少个家庭、最大的家庭中有多少人?
例如:n=6,k=3,三个关系为(1,2),(1,3),(4,5)
此时,6个人组成三个家庭,即:{1,2,3}为一个家庭,{4,5}为一个家庭,{6}单独为一个家庭,第一个家庭的人数为最多。
输入
文件的第一行为n,k二个整数(1≤n≤100)(用空格分隔)
接下来的k行,每行二个整数(用空格分隔)表示关系
输出
二个整数(分别表示家庭个数和最大家庭人数)
样例输入
6 3
1 2
1 3
4 5
样例输出
3 3
思路
这道题用并查集来做比较简单,首先我们将每个成员的父节点定义为自己,然后根据数据,将一家人合并,然后搜索所以成员,如果父节点是自己,则代表一个家庭,只需再求出最大值就行
代码
#include<bits/stdc++.h>
using namespace std;
int father[100001];
int find(int x)//查集
{
if(father[x]!=x)
father[x]=find(father[x]);
return father[x];
}
void unionn(int r1,int r2).//并集
{
father[r2]=r1;
}
int main()
{
int n,m;
scanf("%d %d",&n,&m);
for(int i=1;i<=n;i++)
father[i]=i;//将所有人的父节点定义为自己
for(int i=1;i<=m;i++)
{
int x,y;
scanf("%d %d",&x,&y);
father[x]=find(x);
father[y]=find(y);
if(father[x]!=father[y])//将未合并的一家人合并
unionn(father[x],father[y]);
}
int s=0,max1=0;
for(int i=1;i<=n;i++)
{
int s2=0;
if(find(i)==i)//如果一个人的父节点是自己,代表一个家庭
s++;
for(int j=1;j<=n;j++)
{
if(find(i)==find(j))//如果父节点相同,代表是这个家的人
s2++;//记家人数
}
max1=max(max1,s2);//取最大值
}
cout<<s<<" "<<max1;
}