并查集——营救(洛谷 P1396)
题目选自洛谷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)相关推荐
- 并查集——团伙(洛谷 P1892)
题目选自洛谷P1892 最基础的并查集是给出关系直接合并,这道题呢稍微多了一些条件,就是敌人的敌人也是自己的朋友,所以在合并的时候多了几步操作. 首先,要充分理解题目. "敌人的敌人就是朋友 ...
- 并查集——集合(洛谷 P1621)
题目选自洛谷P1621 一道并查集类型的算法题,基本框架不变,就是合并的时候怎么合并,合并哪些数? 筛出素数之后找出在 'p~b' 范围内的素数 然后枚举a~b之间的数,合并他们 最后看看那些数的祖先 ...
- 并查集——亲戚(洛谷 P1551)
题目选自洛谷P1551 并查集入门题目,简单有趣的例子了解并查集的使用 主要分为三个操作: 1)初始化 没有什么说的,就是用下标当做标号. 2)合并操作 如果两个关系的"老大"不一 ...
- 并查集——家谱(洛谷 P2814)
题目选自洛谷P2814 由于是字符串保存名字,使用数字对应数组来合并查找有一点麻烦,所以使用map将对应关系存起来即可. 因为map带有映射关系,好像不需要再写初始化和合并操作,用两个字符串变量,一个 ...
- 洛谷[P1396]营救 并查集
题目地址http://www.luogu.org/problem/show?pid=1396 P1396拯救膜法师(欸??) 题目描述 "咚咚咚--""查水表!" ...
- 洛谷 P1396 营救
题目链接 https://www.luogu.org/problemnew/show/P1396 题目描述 "咚咚咚--""查水表!"原来是查水表来了,现在哪里 ...
- 洛谷P1396 营救 题解
题目:https://www.luogu.org/problemnew/show/P1396 分析: 这其实一看就是一个最短路的近似模板的题目,但我们要注意到两个区之间可能会有多条道路,所以说我们只需 ...
- 洛谷P1396营救(最小生成树)
题目描述 "咚咚咚--""查水表!"原来是查水表来了,现在哪里找这么热心上门的查表员啊!小明感动的热泪盈眶,开起了门-- 妈妈下班回家,街坊邻居说小明被一群陌生 ...
- 营救(洛谷-P1396)
题目描述 "咚咚咚--""查水表!"原来是查水表来了,现在哪里找这么热心上门的查表员啊!小明感动的热泪盈眶,开起了门-- 妈妈下班回家,街坊邻居说小明被一群陌生 ...
最新文章
- 机器学习实战读书笔记--logistic回归
- 魔幻的“净醛产品”:宜家被罚“亡羊”,欧派用视频“补牢”?
- python中的 and以及or
- arm汇编解析—tengine winograd_nhwc卷积实现
- Kubernetes学习总结(14)—— Kubernetes 实用命令总结
- python 单反格式转格式_如何用单反斜杠转义字符串的特殊字符 - python
- 人工智能工程化丨中小企业AI中台落地指南
- css3动态渐变动画
- Python学习实验报告(1)
- [codeforces 1293A] ConneR and the A.R.C. Markland-N 不超时的二分/无限长数组map+桶排序
- 《一代大商孟洛川》经典台词
- html5 3d场景设计,基于 HTML5 WebGL 的加油站 3D 可视化监控
- 男人二十岁后应该学会的习惯 - 褪墨
- html中屏幕文字轮播怎么做,如何制作网页滚动文字(html)(一)
- 电脑系统id查看教程
- 仅需3分钟,你就能明白Kafka的工作原理
- Python爬虫实战之爬取百度音乐歌曲
- 基础技术篇 2 —— RFID技术(二) - RFID标签分类(按供电方式)
- 已解决Makefile:162:recipe for target ‘all‘ failed
- 【JavaScript】【5】定时器(包含回调函数与Promise)
热门文章
- Java设计模式11:Facade
- 智能物流给力零售业跨越式发展
- 修改的梅花雪的日期控件。。只是一些小改动
- android paint 线宽_Paint setStrokeWidth方法:设置空心线宽
- corners边框_第11天|16天搞定前端,CSS的圆角边框,让人赏心悦目
- raspberry pi_您应该选择哪种Raspberry Pi?
- vis.js入门_使用TensorBoard数据Vis的TensorFlow手术分类器入门
- emacs扩展功能_3个用于组织的Emacs扩展
- eddystone_超级计算机上的Linux,Google的Eddystone和更多新闻
- (28)自动化构建工具Gulp