博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【HDOJ1598】【枚举+最小生成树】
阅读量:5218 次
发布时间:2019-06-14

本文共 1402 字,大约阅读时间需要 4 分钟。

find the most comfortable road

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 8648    Accepted Submission(s): 3648

Problem Description
XX星有许多城市,城市之间通过一种奇怪的高速公路SARS(Super Air Roam Structure---超级空中漫游结构)进行交流,每条SARS都对行驶在上面的Flycar限制了固定的Speed,同时XX星人对 Flycar的“舒适度”有特殊要求,即乘坐过程中最高速度与最低速度的差越小乘坐越舒服 ,(理解为SARS的限速要求,flycar必须瞬间提速/降速,痛苦呀 ),
但XX星人对时间却没那么多要求。要你找出一条城市间的最舒适的路径。(SARS是双向的)。
 
Input
输入包括多个测试实例,每个实例包括:
第一行有2个正整数n (1<n<=200)和m (m<=1000),表示有N个城市和M条SARS。
接下来的行是三个正整数StartCity,EndCity,speed,表示从表面上看StartCity到EndCity,限速为speedSARS。speed<=1000000
然后是一个正整数Q(Q<11),表示寻路的个数。
接下来Q行每行有2个正整数Start,End, 表示寻路的起终点。
 
Output
每个寻路要求打印一行,仅输出一个非负整数表示最佳路线的舒适度最高速与最低速的差。如果起点和终点不能到达,那么输出-1。
 
Sample Input
4 4 1 2 2 2 3 4 1 4 1 3 4 2 2 1 3 1 2
 
Sample Output
1 0
题目大意:就是【多组数据】给一个图,有Q次询问,询问从 顶点 S 到顶点 T 的路径中经过的边中最大值-最小值的最小值是多少,如果S和T不能连通就输出-1
题目分析:对边进行排序【即最小生成树的第一步】,枚举最小值,然后一点点生成树直到S与T连通,将导致S与T连通的那条边【也就是最大权值边】的权值-枚举的那个最小值来更新所求的最小值。
1 #include
2 #include
3 #include
4 #include
5 #include
6 using namespace std; 7 struct edge{ 8 int to; 9 int from;10 int len;11 }EDGE[1005];12 int pre[205];13 int n,m;14 bool cmp(struct edge qaq,struct edge qwq)15 {16 return qaq.len

 

 

转载于:https://www.cnblogs.com/MekakuCityActor/p/9011062.html

你可能感兴趣的文章
Java 内部类
查看>>
mycat 分库分表
查看>>
爬虫-基于scrapy-redis两种形式的分布式爬虫
查看>>
模块_使用M2Crypto加密数据
查看>>
call和apply用途与使用方法
查看>>
函数预解析补充
查看>>
C#中如何启动本地或远程的进程
查看>>
i++
查看>>
文件夹(目录)操作
查看>>
【原创】MYSQL++源码剖析——前言与目录
查看>>
将NavigationBar设置透明
查看>>
Single Number
查看>>
题目2 成绩排序
查看>>
INTERSECT(交集)集合运算
查看>>
上下文字\图片滚动 无JS
查看>>
Linux的动态库与静态库
查看>>
HDU - 1584 IDA*
查看>>
jquery indexOf方法
查看>>
HDU 6579 Operation
查看>>
使用Junit等工具进行单元测试
查看>>