题目选自洛谷P1396

看到最大的最小很多人想到二分,但是可以有更好的解法。

我们不妨用并查集维护这个图,将边从小到大排序,每次取出边权最小的边,若该边的起点与终点未在一个集合内,就将其合并。当源点与汇点在一个集合内时,当前边的权值就是答案。

题目背景

“咚咚咚……”“查水表!”原来是查水表来了,现在哪里找这么热心上门的查表员啊!小明感动得热泪盈眶,开起了门……

题目描述

妈妈下班回家,街坊邻居说小明被一群陌生人强行押上了警车!妈妈丰富的经验告诉她小明被带到了 t 区,而自己在 s 区。

该市有 m 条大道连接 n 个区,一条大道将两个区相连接,每个大道有一个拥挤度。小明的妈妈虽然很着急,但是不愿意拥挤的人潮冲乱了她优雅的步伐。所以请你帮她规划一条从 s 至 t 的路线,使得经过道路的拥挤度最大值最小。

输入格式

第一行有四个用空格隔开的 n,m,s,t,其含义见【题目描述】。

接下来 m 行,每行三个整数 u,v,w,表示有一条大道连接区 u 和区 v,且拥挤度为 w。

两个区之间可能存在多条大道

输出格式

输出一行一个整数,代表最大的拥挤度。

输入输出样例

输入 1

3 3 1 3
1 2 2
2 3 1
1 3 3

输出 1

2

说明/提示

数据规模与约定

  • 对于 30% 的数据,保证 n≤10。
  • 对于 60% 的数据,保证 n≤100。
  • 对于 100% 的数据,保证1≤n≤10^4,1≤m≤2×10^4,w≤10^4,1≤s,t≤n。且从 s 出发一定能到达 t 区。

样例输入输出 1 解释

小明的妈妈要从 1 号点去 3 号点,最优路线为 1->2->3。

解题代码:

#include<stdio.h>
#include<iostream>
#include<stdlib.h>
#include<algorithm>
using namespace std;
const int N = 20020;
int n,m,s,t;
struct edge{int x,y,z;
}e[N];
int f[N];
void init(){for(int i=1;i<=n;i++) f[i] = i;
}
int find(int x){if(f[x] == x) return x;return f[x] = find(f[x]);
}
void merge(int a,int b){if(find(a) != find(b))f[a] = find(f[b]);
}
bool cmp(edge a,edge b){return a.z < b.z;
}
int main(){cin>>n>>m>>s>>t;init();for(int i=1;i<=m;i++){scanf("%d%d%d",&e[i].x,&e[i].y,&e[i].z);}sort(e+1,e+1+m,cmp);for(int i=1;i<=m;i++){int x = find(e[i].x), y = find(e[i].y);if(x != y) merge(x,y);if(find(s) == find(t)){printf("%d",e[i].z);break;}}return 0;
}

并查集——营救(洛谷 P1396)相关推荐

  1. 并查集——团伙(洛谷 P1892)

    题目选自洛谷P1892 最基础的并查集是给出关系直接合并,这道题呢稍微多了一些条件,就是敌人的敌人也是自己的朋友,所以在合并的时候多了几步操作. 首先,要充分理解题目. "敌人的敌人就是朋友 ...

  2. 并查集——集合(洛谷 P1621)

    题目选自洛谷P1621 一道并查集类型的算法题,基本框架不变,就是合并的时候怎么合并,合并哪些数? 筛出素数之后找出在 'p~b' 范围内的素数 然后枚举a~b之间的数,合并他们 最后看看那些数的祖先 ...

  3. 并查集——亲戚(洛谷 P1551)

    题目选自洛谷P1551 并查集入门题目,简单有趣的例子了解并查集的使用 主要分为三个操作: 1)初始化 没有什么说的,就是用下标当做标号. 2)合并操作 如果两个关系的"老大"不一 ...

  4. 并查集——家谱(洛谷 P2814)

    题目选自洛谷P2814 由于是字符串保存名字,使用数字对应数组来合并查找有一点麻烦,所以使用map将对应关系存起来即可. 因为map带有映射关系,好像不需要再写初始化和合并操作,用两个字符串变量,一个 ...

  5. 洛谷[P1396]营救 并查集

    题目地址http://www.luogu.org/problem/show?pid=1396 P1396拯救膜法师(欸??) 题目描述 "咚咚咚--""查水表!" ...

  6. 洛谷 P1396 营救

    题目链接 https://www.luogu.org/problemnew/show/P1396 题目描述 "咚咚咚--""查水表!"原来是查水表来了,现在哪里 ...

  7. 洛谷P1396 营救 题解

    题目:https://www.luogu.org/problemnew/show/P1396 分析: 这其实一看就是一个最短路的近似模板的题目,但我们要注意到两个区之间可能会有多条道路,所以说我们只需 ...

  8. 洛谷P1396营救(最小生成树)

    题目描述 "咚咚咚--""查水表!"原来是查水表来了,现在哪里找这么热心上门的查表员啊!小明感动的热泪盈眶,开起了门-- 妈妈下班回家,街坊邻居说小明被一群陌生 ...

  9. 营救(洛谷-P1396)

    题目描述 "咚咚咚--""查水表!"原来是查水表来了,现在哪里找这么热心上门的查表员啊!小明感动的热泪盈眶,开起了门-- 妈妈下班回家,街坊邻居说小明被一群陌生 ...

最新文章

  1. 机器学习实战读书笔记--logistic回归
  2. 魔幻的“净醛产品”:宜家被罚“亡羊”,欧派用视频“补牢”?
  3. python中的 and以及or
  4. arm汇编解析—tengine winograd_nhwc卷积实现
  5. Kubernetes学习总结(14)—— Kubernetes 实用命令总结
  6. python 单反格式转格式_如何用单反斜杠转义字符串的特殊字符 - python
  7. 人工智能工程化丨中小企业AI中台落地指南
  8. css3动态渐变动画
  9. Python学习实验报告(1)
  10. [codeforces 1293A] ConneR and the A.R.C. Markland-N 不超时的二分/无限长数组map+桶排序
  11. 《一代大商孟洛川》经典台词
  12. html5 3d场景设计,基于 HTML5 WebGL 的加油站 3D 可视化监控
  13. 男人二十岁后应该学会的习惯 - 褪墨
  14. html中屏幕文字轮播怎么做,如何制作网页滚动文字(html)(一)
  15. 电脑系统id查看教程
  16. 仅需3分钟,你就能明白Kafka的工作原理
  17. Python爬虫实战之爬取百度音乐歌曲
  18. 基础技术篇 2 —— RFID技术(二) - RFID标签分类(按供电方式)
  19. 已解决Makefile:162:recipe for target ‘all‘ failed
  20. 【JavaScript】【5】定时器(包含回调函数与Promise)

热门文章

  1. Java设计模式11:Facade
  2. 智能物流给力零售业跨越式发展
  3. 修改的梅花雪的日期控件。。只是一些小改动
  4. android paint 线宽_Paint setStrokeWidth方法:设置空心线宽
  5. corners边框_第11天|16天搞定前端,CSS的圆角边框,让人赏心悦目
  6. raspberry pi_您应该选择哪种Raspberry Pi?
  7. vis.js入门_使用TensorBoard数据Vis的TensorFlow手术分类器入门
  8. emacs扩展功能_3个用于组织的Emacs扩展
  9. eddystone_超级计算机上的Linux,Google的Eddystone和更多新闻
  10. (28)自动化构建工具Gulp