codevs 1001 舒适的路线

2006年

 时间限制: 2 s
 空间限制: 128000 KB
 题目等级 : 钻石 Diamond
 
题目描述 Description

Z小镇是一个景色宜人的地方,吸引来自各地的观光客来此旅游观光。
Z小镇附近共有
N(1<N≤500)个景点(编号为1,2,3,…,N),这些景点被M(0<M≤5000)条道路连接着,所有道路都是双向的,两个景点之间可能有多条道路。也许是为了保护该地的旅游资源,Z小镇有个奇怪的规定,就是对于一条给定的公路Ri,任何在该公路上行驶的车辆速度必须为Vi。频繁的改变速度使得游客们很不舒服,因此大家从一个景点前往另一个景点的时候,都希望选择行使过程中最大速度和最小速度的比尽可能小的路线,也就是所谓最舒适的路线。

输入描述 Input Description

第一行包含两个正整数,N和M。
接下来的M行每行包含三个正整数:x,y和v(1≤x,y≤N,0 最后一行包含两个正整数s,t,表示想知道从景点s到景点t最大最小速度比最小的路径。s和t不可能相同。

输出描述 Output Description

如果景点s到景点t没有路径,输出“IMPOSSIBLE”。否则输出一个数,表示最小的速度比。如果需要,输出一个既约分数。

样例输入 Sample Input

样例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

样例输出 Sample Output

样例1
IMPOSSIBLE

样例2
5/4

样例3
2

数据范围及提示 Data Size & Hint

N(1<N≤500)

M(0<M≤5000)

Vi在int范围内

最最基本的思想:枚举最小边,把和它组合最好的最大边找出来,这样找到所有的最小最大值组合,从其中找到比例最小的。

网上的题解+注释:

 /*
其实这个题目看似是类似于最短路的问题,但实际上与最短路无关。
因为路是双向的,所以我们为了最优的比例,当然可以去走一条无关的路。
可以设计m^2的算法:
先将边按长度排序,然后每次枚举最小边的长度w[i]作限定,依次加入更大的边,
当加到某条边w[j]后,s与t连通(并查集判断),就用w[j]/w[i](double类型)更新答案
若没有w[i]能使s与t连通,则无解 注意:路径中分出的"杈"不用管,因为即使无关,我们也可以走(仅仅是为了那个比例),去掉后s,t仍连通,不会影响答案
*/
#include<stdio.h>
#include<stdlib.h>
int fa[]={},u[]={},v[]={},w[]={};
int father(int x)
{
if(fa[x]!=x) fa[x]=father(fa[x]);
return fa[x];
}
void jh(int* a,int* b)
{
int t=*a;
*a=*b;
*b=t;
}
void kp(int low,int high)
{
int i=low,j=high,mid=w[(i+j)/];
while(i<j)
{
while(w[i]<mid) i++;
while(w[j]>mid) j--;
if(i<=j)
{
jh(&u[i],&u[j]);
jh(&v[i],&v[j]);
jh(&w[i],&w[j]);
i++;
j--;
}
}
if(j>low) kp(low,j);
if(i<high) kp(i,high);
}
int gcd(int a,int b)
{
if(b==) return a;
return gcd(b,a%b);
}
int main()
{
int n,m,i,j,s,t,min=-,max=-;
scanf("%d%d",&n,&m);
for(i=;i<=m;i++)
scanf("%d%d%d",&u[i],&v[i],&w[i]);
scanf("%d%d",&s,&t);
kp(,m);
for(i=;i<=m;i++)//枚举最小边权:w[i]
{
if(w[i]==w[i-]) continue;/*快得不止一点点,这个剪枝,之所以正确,就是因为可以走无关的路,所以最小边的大小不变的话,再建一棵树,结果还是相同的。*/
for(j=;j<=n;j++)
fa[j]=j; /*每次都要建树,所以每次都把并查集初始化*/
for(j=i;j<=m;j++)
{
if(father(u[j])!=father(v[j])) fa[father(u[j])]=father(v[j]);
if(father(s)==father(t)) break; /*用并查集检验s-t是否联通来找的最长边,然后最短边是枚举的,那么就可以很轻易地求出比值了*/
}
if(j<=m&&(min==-||(double)max/(double)min>(double)w[j]/(double)w[i])) /*比值用double,更准*/
{
min=w[i];
max=w[j];
}
}
if(min==-) printf("IMPOSSIBLE");
else
{
if(max%min==) printf("%d",max/min);
else printf("%d/%d",max/gcd(max,min),min/gcd(max,min));
}
return ;
}

my代码:

 #include<iostream>
using namespace std;
#include<cstdio>
#include<algorithm>
#define N 505
#define M 5005
struct Edge{
int u,v,w;
bool operator<(Edge P)
const{return w<P.w;}
}edge[M];
int n,m,s,t,maxx=-,minn=-,father[N];
int gcd(int a,int b)
{
if(!b) return a;
return gcd(b,a%b);
}
void input()
{
scanf("%d%d",&n,&m);
for(int i=;i<=m;++i)
{
scanf("%d%d%d",&edge[i].u,&edge[i].v,&edge[i].w);
}
scanf("%d%d",&s,&t);
}
int find(int x)
{
if(father[x]==x) return x;
return father[x]=find(father[x]);
}
bool kruskal()
{
sort(edge+,edge+m+);
for(int i=;i<=m;++i)
{
if(edge[i].w==edge[i-].w) continue;
int j;
for(j=;j<=n;++j)
father[j]=j;
for(j=i;j<=m;++j)/*j循环要从i开始,因为此时i这条边还没有加入到生成树中*/
{
int x1=find(edge[j].u),x2=find(edge[j].v);
if(x1!=x2)
{
father[x2]=x1;
}
if(find(s)==find(t)) break;
}
if(j<=m&&(minn==-||((double)maxx/(double)minn>(double)edge[j].w/(double)edge[i].w)))
{
minn=edge[i].w;
maxx=edge[j].w;
}
}
if(minn==-) return false;
return true;
}
int main()
{
input();
if(!kruskal())
printf("IMPOSSIBLE\n");
else {
if(maxx%minn==) printf("%d",maxx/minn);
else printf("%d/%d",maxx/gcd(maxx,minn),minn/gcd(maxx,minn));
}
return ;
}

求最大边/最小边的比值最小的路径 codevs 1001 舒适的路线的更多相关文章

  1. poj 1961 Period【求前缀的长度,以及其中最小循环节的循环次数】

    Period Time Limit: 3000MS   Memory Limit: 30000K Total Submissions: 14653   Accepted: 6965 Descripti ...

  2. 最大边和最小边之差最小的生成树 UVA 1394

    题目大意:给你n个点的图,求苗条度(最大边减最小编)尽量小的生成树 思路:sort以后暴力枚举区间即可 //看看会不会爆int!数组会不会少了一维! //取物问题一定要小心先手胜利的条件 #inclu ...

  3. 不同的最小割(cqoi2016,bzoj4519)(最小割树)

    学过图论的同学都知道最小割的概念:对于一个图,某个对图中结点的划分将图中所有结点分成 两个部分,如果结点\(s,t\)不在同一个部分中,则称这个划分是关于\(s,t\)的割.对于带权图来说,将 所有顶 ...

  4. 【poj3522-苗条树】最大边与最小边差值最小的生成树,并查集

    题意:求最大边与最小边差值最小的生成树.n<=100,m<=n*(n-1)/2,没有重边和自环. 题解: m^2的做法就不说了. 时间复杂度O(n*m)的做法: 按边排序,枚举当前最大的边 ...

  5. hdu 1853 Cyclic Tour (二分匹配KM最小权值 或 最小费用最大流)

    Cyclic Tour Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/65535 K (Java/Others)Total ...

  6. Opencv绘制最小外接矩形、最小外接圆

    Opencv中求点集的最小外结矩使用方法minAreaRect,求点集的最小外接圆使用方法minEnclosingCircle. minAreaRect方法原型: RotatedRect minAre ...

  7. 树的问题小结(最小生成树、次小生成树、最小树形图、LCA、最小支配集、最小点覆盖、最大独立集)

    树的定义:连通无回路的无向图是一棵树. 有关树的问题: 1.最小生成树. 2.次小生成树. 3.有向图的最小树形图. 4.LCA(树上两点的最近公共祖先). 5.树的最小支配集.最小点覆盖.最大独立集 ...

  8. bzoj 2229 [Zjoi2011]最小割(分治+最小割)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2229 [题意] 回答若干个关于割不超过x的点对数目的询问. [思路] [最小割最多有n ...

  9. EBS oracle 批量导入更新MOQ(最小拆分量、采购提前期、最小订购量、最小包装量)

    EXCEL的列:组织id,供应商编号,供应商地点,料号,最小拆分量.采购提前期.最小订购量.最小包装量 --采购导入更新MOQ四个值,若有为空的那列,会保留原来的值,不会去更新那列的值 PROCEDU ...

随机推荐

  1. Windows安装apache2.4

    The primary Windows platform for running Apache 2.4 is Windows 2000 or later. Always obtain and inst ...

  2. 【Leafletjs】4.L.Map 中文API

    L.Map API各种类中的核心部分,用来在页面中创建地图并操纵地图. 使用 example // initialize the map on the "map" div with ...

  3. Convert.ChangeType不能处理Nullable类型的解决办法

    在做一个ORMapping功能的时候发现,Convert.ChangeType不能处理nullable类型,比如int?. 解决办法也很简单,贴出完整的代码(大部分代码来自网络),注意下面代码没经过完 ...

  4. 动态改变actionbar上menu的图标

    工作中遇到了一个需求是,在滚动的时候让actionbar上的图标进行变色.实现后在这里总结下思路. 一.先在主题中定义好Actionbar的style <style name="App ...

  5. 编写高质量的Objective-C代码

    点标记语法 属性和幂等方法(多次调用和一次调用返回的结果相同)使用点标记语法访问,其他的情况使用方括号标记语法.   良好的风格: view.backgroundColor = [UIColor or ...

  6. [Android]使用RecyclerView替代ListView(二)

    以下内容为原创,转载请注明: 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/4242541.html 以前写过一篇“[Android]使用Adapte ...

  7. Android Activity和Fragment的转场动画

    Android Activity和Fragment的转场动画 Activity转场动画 Activity的转场动画是通过overridePendingTransition(int enterAnim, ...

  8. 防止IOS6与IOS7图标不一致

    点击AppIcon在属性栏内找到iOS icon is pre-rendered打上勾. 如果之前已经安装过,需要先把APP卸载掉再安装.(因为模拟器有缓存) xcode4版本的话需要在INFO内增加 ...

  9. iOS之 APNs全新的APNs苹果15年WWDC大会上的干货

    记得14年在dl某大学校招上现场面试iOS时候被问到了APNs也就是苹果的推送问题,当时我表示一脸懵逼,因为当时还没有真正接触做过项目也就了解了个大概,总之当时回答的一塌糊涂!后来回去就在网上仔细查了 ...

  10. 开始对函数式编程 产生了尊崇感,因为Spring4.x ,Grooxy,Lisp,网易出来伞哥和他的博客

    1  无意看到"丢弃重口味的xml配置--spring4用groovy配置bean",这篇文章,里面说到spring4开始可以使用Groovy进行配置,可以取代xml方式和注解方式 ...