loj136 (最小瓶颈路,多次询问)
题目描述
给定一个包含 n nn 个节点和 m mm 条边的图,每条边有一个权值。
你的任务是回答 k kk 个询问,每个询问包含两个正整数 s ss 和 t tt 表示起点和终点,要求寻找从 s ss 到 t tt 的一条路径,使得路径上权值最大的一条边权值最小。
输入格式
第一行包含三个整数 n nn、m mm、k kk,分别表示 n nn 个节点, m mm 条路径, k kk 个询问。
接下来 m mm 行,每行三个整数 u uu , v vv , w ww, 表示一个由 u uu 到 v vv 的长度为 w ww 的双向边。
再接下来 k kk 行,每行两个整数 s ss , t tt,表示询问从 s ss 连接到 t tt 的所有路径中单边长度最大值的最小值。
输出格式
输出包含 k kk 行,每一行包含一个整数 p pp 。p pp 表示 s ss 连接到 t tt 的所有路径中单边长度最大值的最小值。另外,如果 s ss 到 t tt 没有路径相连通,输出 -1
即可。
样例
样例输入
8 11 3
1 2 10
2 5 50
3 4 60
7 5 60
3 6 30
1 5 30
6 7 20
1 7 70
2 3 20
3 5 40
2 6 90
1 7
2 8
6 2
样例输出
30
-1
30
数据范围与提示
对于 30% 30\%30% 的数据 n≤100,m≤1000,k≤100,w≤1000 n \leq 100, m \leq 1000, k \leq 100, w \leq 1000n≤100,m≤1000,k≤100,w≤1000
对于 70% 70\%70% 的数据 n≤1000,m≤10000,k≤1000,w≤100000 n \leq 1000, m \leq 10000, k \leq 1000, w \leq 100000n≤1000,m≤10000,k≤1000,w≤100000
对于 100% 100\%100% 的数据 n≤1000,m≤100000,k≤1000,w≤10000000 n \leq 1000, m \leq 100000, k \leq 1000, w \leq 10000000n≤1000,m≤100000,k≤1000,w≤10000000
本题可能会有重边。
为了避免 Special Judge,本题所有的 w ww 均不相同。
题解:
同样是基于最小生成树,我们将其中关键信息保存
#include <bits/stdc++.h>
using namespace std;
const int MAXN=1000+10;
const int INF=0x3f3f3f3f;
int n,m,k;
int mapp[MAXN][MAXN];
int ans[MAXN][MAXN],dis[MAXN],pri[MAXN];
bool vis[MAXN];
void prim()
{
memset(vis, false, sizeof(vis));
for (int i = 1; i <=n ; ++i)
{
dis[i]=INF;
pri[i]=i;
}
dis[1]=0;
for (int i = 1; i <=n ; ++i) {
int MAXX=INF,v=-1;
for (int j = 1; j <=n ; ++j) {
if(!vis[j]&&dis[j]<MAXX)
{
MAXX=dis[v=j];
}
}
if(v==-1)
break;
for (int j = 1; j <=n ; ++j) {
if(vis[j])
{
ans[v][j]=ans[j][v]=max(ans[pri[v]][j],MAXX);
}
}
vis[v]=true;
for (int j = 1; j <=n ; ++j) {
if(!vis[j]&&mapp[v][j]<dis[j])
{
dis[j]=mapp[v][j];
pri[j]=v;
}
}
}
} int main()
{
scanf("%d%d%d",&n,&m,&k);
int x,y,z;
memset(mapp,0x3f, sizeof(mapp));
memset(ans,0, sizeof(ans));
for (int i = 0; i <=n ; ++i) {
mapp[i][i]=0;
}
for (int i = 0; i <m ; ++i) {
scanf("%d%d%d",&x,&y,&z);
if(mapp[x][y]>z)
mapp[x][y]=mapp[y][x]=z;
}
prim();
while(k--)
{
scanf("%d%d",&x,&y); printf("%d\n",ans[x][y]==0?-1:ans[x][y]);
}
return 0;
} //int prim(int s)
//{
// int res=0;
// memset(ans,0,sizeof(ans));// 初始化目标数组
// for(int i=1;i<=n;i++)
// vis[i] = false, d[i] = INF, pri[i]=i;//初始化 标记、距离、父亲数组。
//
// d[s]=0; // 自身的距离为零
// for(int i=0;i<n;i++) // prim考察剩下的n - 1个点
// {
// int maxx=INF, v=-1; // 比较和点的位置
// for(int j=1;j<=n;j++) // 寻找与最小生成树集合最近的点
// {
// if(!vis[j]&&d[j]<maxx)
// {
// maxx=d[v=j]; // 写法不错
// }
// }
// if(v==-1) // 未找到的判断
// break;
//
// for(int j=1;j<=n;j++) //
// if(vis[j])
// ans[v][j] = ans[j][v] = max(ans[pri[v]][j], maxx);
//
// res+=maxx; // 最小生成树权值更新
// vis[v]=true; // 将找到的点加入集合
//
// for(int j=1;j<=n;j++)
// {
// if(!vis[j]&&mapp[v][j]<d[j])
// {
// d[j] = mapp[v][j]; // 更新距离
// pri[j] = v; // 更新父亲节点。
// }
// }
// }
// return res;
//}
loj136 (最小瓶颈路,多次询问)的更多相关文章
- 最小瓶颈路 Uva 534 Frogger
说明:关于Uva的题目,可以在vjudge上做的,不用到Uva(那个极其慢的)网站去做. 最小瓶颈路:找u到v的一条路径满足最大边权值尽量小 先求最小生成树,然后u到v的路径在树上是唯一的,答案就是这 ...
- UVA 11354 Bond(最小瓶颈路+倍增)
题意:问图上任意两点(u,v)之间的路径上,所经过的最大边权最小为多少? 求最小瓶颈路,既是求最小生成树.因为要处理多组询问,所以需要用倍增加速. 先处理出最小生成树,prim的时间复杂度为O(n*n ...
- UVa 11354 邦德(最小瓶颈路+LCA)
https://vjudge.net/problem/UVA-11354 题意: 有n个城市m条道路,每条道路有一个危险系数.先在有若干个询问,要求找到一条从s到t的路,使得途径所有边的最大危险系数最 ...
- BZOJ 3732 Network 最小瓶颈路
题目大意:给出一个无向边,非常多询问,问x,y两地之间的最长路最短是多少. 思路:乍一看好像是二分啊. 的确这个题二分能够做.可是时间会慢非常多,有的题直接就T掉(NOIP2013货车运输). 事实上 ...
- UVALive 5713 Qin Shi Huang's National Road System秦始皇修路(MST,最小瓶颈路)
题意: 秦始皇要在n个城市之间修路,而徐福声可以用法术位秦始皇免费修1条路,每个城市还有人口数,现要求徐福声所修之路的两城市的人口数之和A尽量大,而使n个城市互通需要修的路长B尽量短,从而使得A/B最 ...
- 【UVA534】Frogger 最小瓶颈路
题目大意:给定一张 N 个点的完全图,求 1,2 号节点之间的一条最小瓶颈路. 题解:可知,最小瓶颈路一定存在于最小生成树(最小瓶颈树)中.因此,直接跑克鲁斯卡尔算法,当 1,2 号节点在同一个联通块 ...
- 【20181102T2】飞越行星带【智商题+最小瓶颈路】
题面 [正解] 一眼不可做啊 --相当于求路线上穿过的点最小距离最大 最小最大--二分啊 现在相当于给一个直径,要判断这个直径是否能从左边穿到右边 我们可以在距离不超过直径的点连一条边,\(y=0\) ...
- 【UVA10816】Travel in Desert (最小瓶颈路+最短路)
UVA10816 Travel in Desert 题目大意 沙漠中有一些道路,每个道路有一个温度和距离,要求s,t两点间的一条路径,满足温度最大值最小,并且长度最短 输入格式 输入包含多组数据. 每 ...
- HDU4081:Qin Shi Huang's National Road System (任意两点间的最小瓶颈路)
Qin Shi Huang's National Road System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/3 ...
随机推荐
- TP5.0:引入view视图中公共的模版文件
1.实例:如后台admin模块,公用一个header.html和footer.hml 2.目录结构: 3.视图页面的使用方式: <!--添加header页面数据-->{include fi ...
- 服务器常用命令之 启用/禁用PING状态
启用 echo 0 > /proc/sys/net/ipv4/icmp_echo_ignore_all (PING的通) 禁用 echo 1 > /proc/sys/net/ipv4/i ...
- 配置环境变量时,cmd下运行java -version,报错:找不到或无法加载主类 -version
这个方面适用于报错为:java 找不到或无法加载主类,一般是找不到类的路径,问题出在CLASSPATH环境变量上,当然这是大多数.大概率的出错点 不排除根据个人情况不况,所以想起来伟大领袖毛主席的话: ...
- 从头基于空镜像scratch创建一个新的Docker镜像
我们在使用Dockerfile构建docker镜像时,一种方式是使用官方预先配置好的容器镜像.优点是我们不用从头开始构建,节省了很多工作量,但付出的代价是需要下载很大的镜像包. 比如我机器上docke ...
- IOS ASI 请求服务器 总结
一.发送请求的2个对象 1.发送GET请求:ASIHttpRequest 2.发送POST请求:ASIFormDataRequest* 设置参数// 同一个key只对应1个参数值,适用于普通“单值参数 ...
- bzoj2004 [Hnoi2010]公交线路
Description 小Z所在的城市有N个公交车站,排列在一条长(N-1)km的直线上,从左到右依次编号为1到N,相邻公交车站间的距 离均为1km. 作为公交车线路的规划者,小Z调查了市民的需求,决 ...
- SQLServer用存储过程实现插入更新数据
实现 1)有同样的数据,直接返回(返回值:0): 2)有主键同样,可是数据不同的数据,进行更新处理(返回值:2): 3)没有数据,进行插入数据处理(返回值:1). [创建存储过程] Create pr ...
- mac下登录服务器
1.先通过帐号密码登录到服务器: ssh 用户名@服务器地址 https://jingyan.baidu.com/article/546ae1853132bf1148f28c42.html 2.登录后 ...
- 布局方式-float布局
float的特性一 .元素‘浮动’ .脱离文档流 .但不脱离文本流 首先看一个案例,直观的了解下float的特性 <style> .container{ background: red; ...
- MVC学习一:MVC简单流程
MVC学习一:MVC初次接触 1.MVC简单流程 1.1.服务器接收客户端请求后,解析URL(根据 路由表里配置的URL来分析 类名(控制器名)和方法名)根据请求的类名,创建对应的控制器类对象,并调用 ...