Luogu 1111 修复公路(最小生成树)

Description

A地区在地震过后,连接所有村庄的公路都造成了损坏而无法通车。政府派人修复这些公路。

给出A地区的村庄数N,和公路数M,公路是双向的。并告诉你每条公路的连着哪两个村庄,并告诉你什么时候能修完这条公路。问最早什么时候任意两个村庄能够通车,即最早什么时候任意两条村庄都存在至少一条修复完成的道路(可以由多条公路连成一条道路)

Input

第1行两个正整数N,M

下面M行,每行3个正整数x, y, t,告诉你这条公路连着x,y两个村庄,在时间t时能修复完成这条公路。

Output

如果全部公路修复完毕仍然存在两个村庄无法通车,则输出-1,否则输出最早什么时候任意两个村庄能够通车。

Sample Input

4 4

1 2 6

1 3 4

1 4 5

4 2 3

Sample Output

5

Http

Luogu:https://www.luogu.org/problem/show?pid=1111

Source

最小生成树 并查集

题目大意

求图中满足所有点联通的边的集合中最大值最下(说得简单点,就是求一个图的最小生成树并输出树上的最大边)

解决思路

首先用克鲁斯卡尔算法求出最小生成树,具体做法是:

  1. 将所有的边按照边权值从小到大排序
  2. 从第一条边开始枚举,每次判断这条边的两端点,若都已经在一个连通块里了,跳过,若不在,连接这条边并合并这两个连通块
  3. 持续上述操作,直到连接了n-1条边(为什么是n-1条呢?因为一棵树的边就是n-1条啊)或是所有的边都扫描过了(此时代表无解,原图不连通)

那么现在的问题就是如何判断两个点已经在同一连通块中了呢?

没错!我们用并查集来判断连通块。

定义一个F[i](代码中用Mayuri[i])来表示i所属的并查集编号。开始时每一个点都是一个孤立的连通块,所以每一个F[i]=i。在合并两个点u,v时,只要将u,v所在的并查集合并就可以将两个连通块合并了,具体操作就是将F[u]置为F[v],但这样是有问题的,因为u所在的并查集编号并不一定是F[u],所以要一直向上搜寻,我们用一个Find()函数来表示,递归地找到最早的编号。

但是这样有可能出现树退化成链表的情况,所以在Find函数查找时,顺便压缩路径(具体请看代码)

代码

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std; class Road
{
public:
int u,v,w;
}; bool operator < (Road a,Road b)//因为要排序,所以重载一下小于运算符
{
return a.w<b.w;
} const int maxN=2000;
const int maxM=101000;
const int inf=2147483647; int n,m;
int Mayuri[maxN];
Road E[maxM]; int Find(int x); int main()
{
int Ans=0;
int cnt=0;
cin>>n>>m;
for (int i=1;i<=m;i++)
{
cin>>E[i].u>>E[i].v>>E[i].w;
}
sort(&E[1],&E[m+1]);
for (int i=1;i<=n;i++)//并查集初始化
Mayuri[i]=i;
int i=0;
do
{
i++;
int fu=Find(E[i].u);
int fv=Find(E[i].v);
if (fu!=fv)//如果u,v不在同一个连通块,就合并
{
cnt++;//统计选择了的边的个数,便于及时退出和判断是否有解
Ans=max(E[i].w,Ans);//更新答案
Mayuri[fu]=fv;
}
if (cnt==n-1)//当已经形成一个树时,及时退出循环
break;
}
while (i<m);
if (cnt==n-1)
cout<<Ans<<endl;
else
cout<<-1<<endl;
return 0;
} int Find(int x)
{
if (Mayuri[x]!=x)
Mayuri[x]=Find(Mayuri[x]);//压缩路径,让每一个点都直接指向其并查集编号的那个点
return Mayuri[x];
}

Luogu 1111 修复公路(最小生成树)的更多相关文章

  1. Luogu P1265修复公路【Prim最小生成树】By cellur925

    题目传送门 政府审批的规则如下: (1)如果两个或以上城市申请修建同一条公路,则让它们共同修建: (2)如果三个或以上的城市申请修建的公路成环.如下图,A申请修建公路AB,B申请修建公路BC,C申请修 ...

  2. [LUOGU] P1111 修复公路

    题目背景 A地区在地震过后,连接所有村庄的公路都造成了损坏而无法通车.政府派人修复这些公路. 题目描述 给出A地区的村庄数N,和公路数M,公路是双向的.并告诉你每条公路的连着哪两个村庄,并告诉你什么时 ...

  3. 最小生成树 kruskal算法 codevs 1638 修复公路

    1638 修复公路  时间限制: 1 s  空间限制: 256000 KB  题目等级 : 钻石 Diamond 题解       题目描述 Description A地区在地震过后,连接所有村庄的公 ...

  4. P1111 修复公路

    P1111 修复公路 550通过 1.6K提交 题目提供者该用户不存在 标签并查集 难度普及/提高- 提交该题 讨论 题解 记录   题目背景 A地区在地震过后,连接所有村庄的公路都造成了损坏而无法通 ...

  5. [LuoguP1111]修复公路

    [LuoguP1111]修复公路 题目描述: A地区在地震过后,链接所有村庄的公路都损坏了,而导致无法通车,政府派人修复这些公路. 给出A地区的N村庄数和M公路数,并且对于每一个公路给出其链接的两个村 ...

  6. 洛谷 P1111 修复公路(最小生成树)

    嗯... 题目链接:https://www.luogu.org/problemnew/show/P1111 这道题的关键是读懂题: 首先根据题中的一些扎眼的字眼我们可以判断这是一道用最小生成树来做的题 ...

  7. (最小生成树 并查集)P1111 修复公路 洛谷

    题目背景 A地区在地震过后,连接所有村庄的公路都造成了损坏而无法通车.政府派人修复这些公路. 题目描述 给出A地区的村庄数N,和公路数M,公路是双向的.并告诉你每条公路的连着哪两个村庄,并告诉你什么时 ...

  8. 洛谷 P1111 修复公路

    题目链接 https://www.luogu.org/problemnew/show/P1111 以后只发题目链接!!! 题目大意 给出A地区的村庄数N,和公路数M,公路是双向的.并告诉你每条公路的连 ...

  9. P1111 修复公路 洛谷

    https://www.luogu.org/problem/show?pid=1111 题目背景 A地区在地震过后,连接所有村庄的公路都造成了损坏而无法通车.政府派人修复这些公路. 题目描述 给出A地 ...

随机推荐

  1. 深入理解CSS3 Flexbox

    一.前言 Flexbox 是一个 CSS3 的盒子模型 ( box model ),顾名思义它就是一个灵活的盒子 ( Flexible Box ),为什麽最近这个属性才红起来呢?最主要也是因为 CSS ...

  2. Windows、Office系列产品精华部分集锦

    提示 有了这个帖子麻麻再也不用担心我因为四处找Microsoft家的软件和系统而四处劳累所烦恼了! 首先,你们最爱的老XP同志,XP同志虽然退休了,但是依然坚持在岗位上,向他致敬!! Windows ...

  3. javascript基础-事件1

    原理 事件分两种.第一种浏览器事件,由浏览器抛出事件,它是人机交互的基础:第二种自定义事件,由程序员抛出事件,它是模拟事件流程.两者都是为了完成数据的传递. 浏览器事件 机制 冒泡和捕获两种机制.因I ...

  4. 浅谈MVC数据验证

    一.一般情况 对于使用过MVC框架的人来说,对MVC的数据验证不会陌生,比如,我有一个Model如下: public class UserInfo { [Required(ErrorMessage = ...

  5. C/C++遍历目录下的所有文件(Windows篇,超详细)

    注: 1. 本文讨论的是怎么用Windows API遍历目录下的所有文件.除Windows API,还有一种Windows/Linux通用的方式,使用<io.h>. 2. 本文部分翻译自M ...

  6. Linux OS共享文件

    背景: 相较于windows.unix等OS,Linux因为其开源.安全.稳定.性能优越等优点,已越来越受到互联网的青睐.而我们在学习和使用Linux也就会考虑到Linux机器和我们日常用的windo ...

  7. mac安装as配置

    /Users/admin/Library/Android/sdk export PATH=${PATH}:/Users/admin/Library/Android/sdk/tools:/Users/a ...

  8. 学习web前端怎样入门?初学者赶紧看过来!

    web前端怎么样才能入门,首先我们要从什么是初级web前端工程师说起: 按照我的想法,我把前端工程师分为了入门.初级.中级.高级这四个级别, 入门级别指的是了解什么是前端(前端到底是什么其实很多人还是 ...

  9. 简单两步快速学会使用Mybatis-Generator自动生成entity实体、dao接口和简单mapper映射(用mysql和oracle举例)

    前言: mybatis-generator是根据配置文件中我们配置的数据库连接参数自动连接到数据库并根据对应的数据库表自动的生成与之对应mapper映射(比如增删改查,选择性增删改查等等简单语句)文件 ...

  10. Spring学习(16)--- 基于Java类的配置Bean 之 基于泛型的自动装配(spring4新增)

    例子: 定义泛型Store package javabased; public interface Store<T> { } 两个实现类StringStore,IntegerStore p ...