1362:家庭问题(family)

news/2024/11/20 8:34:59/

1362:家庭问题(family)


时间限制: 1000 ms         内存限制: 65536 KB
提交数: 6732     通过数: 3529

【题目描述】

有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

闲话:这道题说实话我当时学队列时没做出来这道题,后来学了并查集才做出来(说实话我不知道这道题为什么被放在队列的分类里)


并查集模板

join函数:

void join(int p,int q)
{int fp = fin(p),fq = fin(q);if(fp != fq) fa[fq] = fp;
}

fin函数:

int fin(int k)
{if(k == fa[k]) return k;return fa[k] = fin(fa[k]);
}

 思路:这道题要求输出家庭个数和最大家庭人数,家庭个数很简单,构造好并查集后直接数数有多少人的老大是他自己就知道了。可最大家庭人数该怎么求呢?我也是这里掉了几次坑。我的做法是先把每个人的最牛boss的编号存储在fa[i]中,再排序,然后判断,如果第i个人的最大boss==第i - 1个人的最大boss则说明出现了一个新家庭,把rs与用来数前一个家庭有几人的变量s取最大值,然后将s初始化为1,否则s++。


坑点:最后还需要

rs = max(rs,s);

!因为如果只有 1个家庭,则数最大家庭人数时根据前面的逻辑,fa[i]会一直等于fa[i - 1],此时就会输出1。不行可以注释掉这一行代码试试下面的样例

 10 10
  1 2
  1 3
  3 4
  2 5
  3 2
  3 6
  7 8
  7 9
  8 10
  7 2

我前面就是因为没有这一行代码而 


代码:

#include <bits/stdc++.h>
using namespace std;
int s = 1,n,m,z,x,y,fa[100001],l,gs,rs;
int fin(int k)
{if(k == fa[k]) return k;return fa[k] = fin(fa[k]);
}
void join(int p,int q)
{int fp = fin(p),fq = fin(q);if(fp != fq) fa[fq] = fp;
}
int main()
{scanf("%d%d",&n,&m);for(int i = 1;i <= n;i++) fa[i] = i;while(m--){scanf("%d%d",&x,&y);join(x,y);}for(int i = 1;i <= n;i++){if(fa[i] == i) gs++;fa[i] = fin(i);}sort(fa + 1,fa + 1 + n);//for(int i = 1;i <= n;i++) cout<<fa[i]<<" ";for(int i = 1;i <= n;i++)if(fa[i] == fa[i - 1]) s++;else{rs = max(rs,s);s = 1;}rs = max(rs,s);printf("%d %d",gs,rs);return 0;
}
/*10 101 21 33 42 53 23 67 87 98 107 2*/

 


http://www.ppmy.cn/news/5505.html

相关文章

vue3项目打包部署到Tomcat(亲测有效)

首先&#xff0c;要确保电脑上已经安装了jdk&#xff0c;还有Tomcat&#xff0c;而且都安装正确。 jdk下载与安装教程&#xff08;win10&#xff09; Tomcat 9.0 安装及配置教程(win10系统) Vue项目在VScode里面可以通过npm run serve可以正常运行。 下面是打包部署到tomca…

22年D2部分干货

缘起 小编入行以来&#xff0c;一直兢兢业业&#xff0c;跟随大佬们脚步&#xff0c;学习如何努力成为优秀的开发。机缘巧合&#xff0c;在2017年小编接触到了前端峰会——D2&#xff0c;里面好多大佬聊未来的趋势。记得疫情之前&#xff0c;D2采用的是线下邀请&#xff0c;可惜…

浅谈安科瑞电能预付费系统在大电力客户中的设计及应用分析

摘 要 随着我国供电企业的不断发展&#xff0c;而用电模式也在不断改革&#xff0c;预付费技术在气、电等部门得到普遍的使用&#xff0c;本文主要针对预付费系统在大电力客户中的使用情况进行分析&#xff0c;提高用电用户的缴费率&#xff0c;有效的避免了客户恶意偷窃电行…

35. 搜索插入位置

给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 示例 1: 输入: nums [1,3,5,6], target 5 输出: 2示例 2: 输入:…

vpp process类型节点调度过程

vpp节点类型 VLIB_NODE_TYPE_PROCESS&#xff1a;process类型节点可以被挂起也可以被恢复&#xff0c;main线程上调度 &#xff08;免费订阅,永久学习&#xff09;学习地址: Dpdk/网络协议栈/vpp/OvS/DDos/NFV/虚拟化/高性能专家-学习视频教程-腾讯课堂 process节点注册 pro…

著作权范围大于版权?如何进行著作权查询?

我们知道&#xff0c;创作者申请著作权是保护自己版权的重要措施&#xff0c;著作权就是平常我们口中所说的版权。随着社会发展&#xff0c;对于著作权的重视增加&#xff0c;侵权行为也逐渐减少。那么著作权的具体内涵是什么&#xff0c;国家著作权怎样查询? (一)国家著作权…

HDFS教程(一)

目录 1. HDFS 简介 2. HDFS 节点 2.1 HDFS Master 节点&#xff08;Namenode&#xff09; 2.2 HDFS Slave 节点&#xff08;Datanode&#xff09; 3. HDFS 特性 3.1 分布式存储 3.2 高可用 3.3 可扩展性 3.3 高吞吐量 1. HDFS 简介 HDFS&#xff08;Hadoop Distribute…

容器云的双活与灾备技术

在多中心多云环境下&#xff0c;可将容器云部署为多活和灾备模式&#xff0c;通过全局负载均衡器实现应用的多中心多活与灾备。容器应用跨数据中心的双活&#xff0c;是将一个应用的不同副本部署到不同的数据中心&#xff0c;如图 1 所示的 Database 应用。 图1 Database应用双…