P1536 村村通(洛谷)并查集
隔壁的dgdger带我看了看老师的LCA教程,我因为学习数学太累了(就是懒),去水了一下,感觉很简单的样子,于是我也来写(水)个博客吧。
题目描述
某市调查城镇交通状况,得到现有城镇道路统计表。表中列出了每条道路直接连通的城镇。市政府 "村村通工程" 的目标是使全市任何两个城镇间都可以实现交通(但不一定有直接的道路相连,只要相互之间可达即可)。请你计算出最少还需要建设多少条道路?
输入格式
输入包含若干组测试测试数据,每组测试数据的第一行给出两个用空格隔开的正整数,分别是城镇数目n和道路数目m
随后的m行对应m条道路,每行给出一对用空格隔开的正整数,分别是该条道路直接相连的两个城镇的编号。简单起见,城镇从
1到n编号。
注意:两个城市间可以有多条道路相通。
输出格式
对于每组数据,对应一行一个整数。表示最少还需要建设的道路数目。
看这个题板像极了并查集(就是)我们加上一点点优化就可以变成LCA(最近公共祖先)。
首先我们先说说并查集怎么做:并查集就是把相连接的点放到一个集合里,就像战争一样,一个士兵遇见了另一个,2人如果不是同一个主公的士兵,就会打起来(不会有士兵自相残杀吧),那怎么判断他们两个是不是同一个主公的士兵呢?当然是飞鸽传书给自己的将军,将军要给将军的将军飞鸽传书……等传到2人主公那里,主公再告诉他们,得知2人的主公是同一人后,2人就会和谐离去,不是同一人,2人就会打起来,输了的那个会劝说自己的主公和对方主公合作(因为训练机制一样,一个打不过一队肯定也打不过,不过这真是太和谐了)。蛋是,士兵们不傻……战场上这么多人,每次都要向上级不断的问也太费劲了,于是士兵们相处了一个好办法,已经知道自己的主公是谁时,只要去问问主公,自己有没有投靠别的主公,如果有,就继续问。而且中途的将军和主公们也记下自己最大的主公是谁,这样以后查找就会轻松很多啦。(其实这就是很简单的LCA)
现在这个题相当于给出了每个士兵的战况,但现在主公们想要和谐相处,问他们还要让士兵打几架?
#include<iostream>
#include<cstdio>
using namespace std;
long long n,m,a,b,shu;
long long f[1005];
int zbb(int wz)
{
if(f[wz]==wz)//如果现在这位是最大的主公,就可以退出了
{
return wz;
}
f[wz]=zbb(f[wz]);//中间迷茫的将军们找到了自己为谁而厮杀
return f[wz];//让将军告诉我
}
int main()
{
while(true)
{
scanf("%lld",&n);//给出势力的数量
if(n==0)
{
return 0;
}
shu=0;//势力的初始化
for(int i=1;i<=n;i++)
{
f[i]=i;
}
scanf("%lld",&m);//给出打了多少架
for(int i=0;i<m;i++)
{
cin>>a>>b;//给出双方
f[zbb(a)]=zbb(b);//假设b赢了,a的势力投靠b
}
for(int i=1;i<=n;i++)
{
if(f[i]==i)//这个势力没投靠过任何人,是一个单独的势力
{
shu++;
}
}
cout<<shu-1<<endl;//一共有shu个单独势力,要求剩下一个,所以要打shu-1架
}
return 0;
}
哎呀我真是机智,士兵们都会感谢我的。
P1536 村村通(洛谷)并查集的更多相关文章
- P1536 村村通 洛谷
https://www.luogu.org/problem/show?pid=1536 题目描述 某市调查城镇交通状况,得到现有城镇道路统计表.表中列出了每条道路直接连通的城镇.市政府“村村通工程”的 ...
- 洛谷—— P1536 村村通
P1536 村村通 题目描述 某市调查城镇交通状况,得到现有城镇道路统计表.表中列出了每条道路直接连通的城镇.市政府“村村通工程”的目标是使全市任何两个城镇间都可以实现交通(但不一定有直接的道路相连, ...
- 洛谷 P1536 村村通
目录 题目 思路 \(Code\) 题目 P1536 村村通 思路 并查集,一开始连通快的数量为\(n\),输入\(m\)条边时如果该边起点和终点不在同一联通块内就合并并让联通块数量减一,最后输出联通 ...
- P1536 村村通
原题链接 https://www.luogu.org/problemnew/show/P1536 昨天刚学的并查集,今天正好练习一下,于是就找到了这个题 看起来好像很简单,尤其是你明白了思路之后,完全 ...
- 洛谷 P1536 村村通(并查集)
嗯... 题目链接:https://www.luogu.org/problemnew/show/P1536 思路: 这道题可以看出是并查集的思想,然后用一个while嵌套一下,输入一条路的两个端点,就 ...
- 【洛谷】【最小生成树】P1536 村村通
[题目描述:] 某市调查城镇交通状况,得到现有城镇道路统计表.表中列出了每条道路直接连通的城镇.市政府"村村通工程"的目标是使全市任何两个城镇间都可以实现交通(但不一定有直接的道路 ...
- [洛谷P1536]村村通
题意:多组数据,当n为0时结束,每组数据表示有n个村子,m条路,求还需要建多少条路,使得所有的村子联通题解:用并查集求出有多少个联通块,然后求解 C++ Code: #include<cstdi ...
- P1536村村通
这是一个并查集的题,被洛谷评为提高—. 拿到这个题便看出了这是一个裸的并查集,于是就写了一个模板,结果发现连输入都输不进去,一看竟然是多组数据,,然后看到N==0结束,于是便加了一层while.之后提 ...
- 【luogu P1536 村村通】 题解
题目链接:https://www.luogu.org/problemnew/show/P1536 并查集的运用,可以用生成树的思想,就是n个点生成一棵树需要n-1条边.这样我们先把已有的路连接到一个并 ...
随机推荐
- Win10下创建virtualenv Linux下创建
虚拟环境 为什么要搭建虚拟环境 开发多个不同的项目 可能需要用到同一个包不同版本新版本会覆盖旧的 作用 虚拟环境 可以搭建独立的Python运行环境 使项目之间版本不受影响 Linux下如何搭建虚拟环 ...
- Java二次复习笔记(1)
Java二次复习笔记(1) Java采用的默认字符编码集是Unicode. byte=byte+byte报错,值为int,而byte+=byte不报错.同样short = short+short报错, ...
- elasticSearch中集群状态的guan'l
es中集群出现上面的问题一般是磁盘空间不够引起的,就是node节点所在的磁盘空间不足引起的 es整个集群放在c盘,都快满了 说明es的磁盘已经快被使用完了,我们可以临时更新下磁盘空间大小 修改 ES分 ...
- Oracel中coalesce函数的用法
1.coalesce函数的用法 1.1 取出第一个不为空的列的数据.
- Python实用笔记——错误处理
让我们用一个例子来看看try的机制: try: print('try...') r = 10 / 0 print('result:', r) except ZeroDivisionError as e ...
- ajax前后端交互原理(5)
5.ajax简介 5.1.什么是ajax Asynchronous JavaScript and XML ,异步的javascript和XML 5.2.使用ajax有什么用 数据交互,可以从服务器获取 ...
- 基于 fetch 的请求封装
原生 fetch 请求失败后(如无网络)状态会变成 reject 走 .catch .绝大多数情况下业务场景只需要给个 toast 等简单处理.每个请求都 .catch 会显得格外繁琐,并且如果不 . ...
- Python进阶之浅谈内置方法(补充)
目录 列表类型的内置方法 元组类型的内置方法 字典类型的内置方法 集合类型的内置方法 列表类型的内置方法 1.作用:描述名字,说的话等 2.定义方式 s=['tim','age'] s=str('ti ...
- pycharm中导入包失败的解决办法
将鼠标移动到requests处,出现如下提示 按住alt+enter键,点击install package requests即可安装requests包 安装成功后
- 优雅关闭服务下线(Jetty)
在很多时候 kill -9 pid并不是很友好的方法,那样会将我们正在执行请求给断掉,同时eureka 中服务依旧是处于在线状态,这个时候我们可以使用官方提供的actuator来做优雅的关闭处理 - ...