BZOJ 1050 旅行comf
题目如下:
题目描述
给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000)。给你两个顶点S和T,求一条路径,使得路径上最大边和最小边的比值最小。如果S和T之间没有路径,输出”IMPOSSIBLE”,否则输出这个比值,如果需要,表示成一个既约分数。 备注: 两个顶点之间可能有多条路径。
输入
第一行包含两个正整数,N和M。 下来的M行每行包含三个正整数:x,y和v。表示景点x到景点y之间有一条双向公路,车辆必须以速度v在该公路上行驶。 最后一行包含两个正整数s,t,表示想知道从景点s到景点t最大最小速度比最小的路径。s和t不可能相同。
输出
如果景点s到景点t没有路径,输出“IMPOSSIBLE”。否则输出一个数,表示最小的速度比。如果需要,输出一个既约分数。
样例输入
【样例输入1】
4 2
1 2 1
3 4 2
1 4
【样例输入2】
3 3
1 2 10
1 2 5
2 3 8
1 3
【样例输入3】
3 2
1 2 2
2 3 4
1 3
样例输出
【样例输出1】
IMPOSSIBLE
【样例输出2】
5/4
【样例输出3】
2
用结构体存边:E[ ].fr(起始点) E[ ].to(指向点) E[ ].cost(权值)
此题用的是并查集来做的。首先对所有的边进行从小到大排序,定义ans1=inf为当前寻找到的最大边的最小值,ans2=1位当前的最小边。然后从小到大进行枚举(循环一:for(i=1;i<=m;i++))在循环一中建立以点为关键字的并查集数组。再进行第二重循环(for(int j=i;j<=n;j++)),该循环是从循环一进行到的边的编号开始,到最大的边,每添加一条边,将其开头和结尾添加在并查集中,再检测S和T的连通性即(if(find(S)==find(T)){ }),若联通则比较ans1/ans2与E[ j ].cost/E[ i ].cost的大小比较过程中可以交叉相乘,这样可以避免整除的问题。若新的比值更小则更新ans1和ans2的值并跳出循环二。若不连通依然比较ans1/ans2与E[ j ].cost/E[ i ].cost的大小,若新的比值小于原存的比值,则跳出循环二,因为循环二中E[j].cost是不断增大的。循环一结束后,主体就结束了,最后的输出一看就懂。
#include
<cstdio>
#include
<algorithm>#define inf 10000000
using namespace std;
struct edge{
int fr,to,cost;
};
edge E[];
inline int comp(edge a,edge b)
{
return a.cost<b.cost;
}
int m,n,s,t;
int fa[];
inline int find(int x)
{
if(fa[x]!=x) fa[x]=find(fa[x]);
return fa[x];
}
inline int gcd(int a,int b)//a>b
{
if(b==) return a;
return gcd(b,a%b);
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++)
scanf("%d%d%d",&E[i].fr,&E[i].to,&E[i].cost);
scanf("%d%d",&s,&t);
sort(E+,E+m+,comp);
int ans1=inf,ans2=;
for(int i=;i<=m;i++){
for(int j=;j<=n;j++)
fa[j]=j;
for(int j=i;j<=m;j++){
int f1=find(E[j].fr),f2=find(E[j].to);
fa[f1]=f2;
if(find(s)==find(t)){
if(E[i].cost*ans1>E[j].cost*ans2)
ans1=E[j].cost,ans2=E[i].cost;
break;
}
if(E[i].cost*ans1<E[j].cost*ans2) break;
}
}
int zdg=gcd(ans1,ans2);
if(ans1==inf) printf("IMPOSSIBLE");
else if(ans2!=zdg) printf("%d/%d",ans1/zdg,ans2/zdg);
else printf("%d",ans1/ans2);
}
BZOJ 1050 旅行comf的更多相关文章
- BZOJ 1050 旅行comf(枚举最小边-并查集)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1050 题意:给出一个带权图.求一条s到t的路径使得这条路径上最大最小边的比值最小? 思路 ...
- BZOJ 1050 旅行comf 并查集+枚举下界
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1050 题目大意: 给你一个无向图,N(N<=500)个顶点, M(M<=5 ...
- [BZOJ]1050 旅行comf(HAOI2006)
图论一直是小C的弱项,相比其它题型,图论的花样通常会更多一点,套路也更难捉摸. Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权 ...
- HYSBZ - 1050(旅行comf 并查集Java实现)
HYSBZ - 1050(旅行comf Java实现) 原题地址 解法:枚举每一条边,对于这条边,我们需要找到集合中和其值相差最小的最大边,这个集合是指与包括i边在内的ST联通集.对于这一要求,我们只 ...
- BZOJ 1050 旅行
Description 给你一个无向图,N(N<=500)个顶点, M(M<=5000)条边,每条边有一个权值Vi(Vi<30000).给你两个顶点S和T,求一条路径,使得路径上最大 ...
- BZOJ 1050 旅行(并查集)
很好的一道题.. 首先把边权排序.然后枚举最小的边,再依次添加不小于该边的边,直到s和t联通.用并查集维护即可. # include <cstdio> # include <cstr ...
- BZOJ [HAOI2006]旅行comf
题解:枚举最大边,然后对<=最大边的边做最大生成树,使最小边最大 #include<iostream> #include<cstdio> #include<cstr ...
- 【BZOJ】【1050】【HAOI2006】旅行comf
枚举/暴力/Kruskal orz……我sb了……其实是sb题<_< 有一道题问的是最小极差生成树……(不记得是什么名字了,就是求最大边权与最小边权差最小的生成树)做法是枚举最小边,然后k ...
- BZOJ 1050 [HAOI2006]旅行comf
1050: [HAOI2006]旅行comf Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1889 Solved: 976[Submit][Sta ...
随机推荐
- git配置别名
配置别名 有没有经常敲错命令?比如git status?status这个单词真心不好记. 如果敲git st就表示git status那就简单多了,当然这种偷懒的办法我们是极力赞成的. 我们只需要 ...
- GDKOI2015 Day1
P1 题目描述: 判断一个环形字符串(或者减去一个字符之后)是否是回文串 solution: 1.hash 将字符串的前缀进行hash,然后将字符串翻转,再做一次hash,然后枚举对称轴,判断两边的h ...
- javascript if 与 if else 的一点小认识
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- PLSQl远程连接oracle数据库
PLSQL远程连接Oracle 10G 1.在安装ORACLE服务器的机器上搜索下列文件, ORACLE 服务器上的文件 oci.dll ocijdbc10.dll ociw32.dl ...
- 【每日一摩斯】-Troubleshooting: High CPU Utilization (164768.1) - 系列6
如果问题是一个正运行的缓慢的查询SQL,那么就应该对该查询进行调优,避免它耗费过高的CPU资源.如果它做了许多的hash连接和全表扫描,那么就应该添加索引以提高效率. 下面的文章可以帮助判断查询的问题 ...
- SQlSERVER生成唯一编号
基数表-用来存储编号前缀和类型 建表如下 CREATE TABLE [dbo].[SerialNo]( [sCode] [varchar](50) NOT NULL, [sName] [varchar ...
- EAX、ECX、EDX、EBX寄存器的作用(转)
一般寄存器:AX.BX.CX.DXAX:累积暂存器,BX:基底暂存器,CX:计数暂存器,DX:资料暂存器 索引暂存器:SI.DISI:来源索引暂存器,DI:目的索引暂存器 堆叠.基底暂存器:SP.BP ...
- BZOJ 2324: [ZJOI2011]营救皮卡丘( floyd + 费用流 )
昨晚写的题...补发一下题解... 把1~N每个点拆成xi, yi 2个. 预处理i->j经过编号不超过max(i,j)的最短路(floyd) S->0(K, 0), S->xi(1 ...
- apache rewrite rule
http://10.58.104.19:8008/site/833/3f11d2b44b7d3baa2149f26a30f8c68d/b.js?siteid=332323 将一个静态请求转换成一个动态 ...
- 静态资源库CDN服务
使用静态资源库可以访问线上资源文件,比如jquery库.bootstrap库.使用百度静态资源库的居多,但是发现百度暂时不支持https协议,bootcdn是一个不错的选择. 百度静态资源公共库 优点 ...