首页 技术 正文
技术 2022年11月10日
0 收藏 324 点赞 4,756 浏览 947 个字

题目描述

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

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

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

输入输出格式

输入格式:

第一行四个数字n,m,s,t。

接下来m行,每行三个数字,分别表示两个区和拥挤度。

(有可能两个区之间有多条大道相连。)

输出格式:

输出题目要求的拥挤度。

这道题目有2种做法:

1.kruskal

2.二分

对于第一种算法,我们知道最小的路一定在最小生成树上。这道题的原理可同NOIP货车运输

对于第二种算法,我们发现这道题的答案具有结论单调性,所以我们可以二分答案,然后用链表处理即可、。

下面贴第一种算法的代码

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int n,m,s,t;
struct edge{
int x,y,k;
}bian[];
int f[];
bool cmp(edge a,edge b){return a.k<b.k;}
int getfa(int x){return x==f[x]?x:f[x]=getfa(f[x]);}
int main(){
scanf("%d%d%d%d",&n,&m,&s,&t);
for(int i=;i<=m;i++)
scanf("%d%d%d",&bian[i].x,&bian[i].y,&bian[i].k);
sort(bian+,bian+m+,cmp);
for(int i=;i<=n;i++)
f[i]=i;
for(int i=;i<=m;i++)
{
int x=getfa(f[bian[i].x]),y=getfa(f[bian[i].y]);
if(x!=y)f[x]=y;
if(getfa(f[s])==getfa(f[t]))
{
printf("%d\n",bian[i].k);
break;
}
}
return ;
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,492
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,907
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,740
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,495
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,132
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,295