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范围内

 
 
思路:
  其实我是想不出答案来的
  所以看了一下别人的思路
  现在又要在博客里重复一下这个思路
  因为数据范围小所以我们选择暴力
  先将所有的边都存起来
  然后按照dis值从小到大排序
  然后我们第一个遍循环枚举从哪条边开始
  这条开始边的dis值就是我们当前状态的最小速度
  然后第二重循环从当前边向后寻找
  如果当前扫到的边的from和to不连通
  我们使之联通并且更新最大速度值
  如果start和end联通则break
  然后所有的最大速度与最小速度之比取最优就是答案
  如果所有的start与end不联通则impossible
  这里再说一下既分约数
  就是分子与分母同处最大公约数
 
 
来,上代码:

#include<cstdio>
#include<algorithm> using namespace std; struct node {
int from,to,dis;
};
struct node edge[]; int n,m,f[],ans_max,ans_min,maxn,minn,start,end; inline void edge_add(int from,int to,int dis,int now)
{
edge[now].to=to;
edge[now].dis=dis;
edge[now].from=from;
} bool cmp(struct node SOME_1,struct node SOME_2){return SOME_1.dis<SOME_2.dis;} int find(int x)
{
if(f[x]==x) return f[x];
else return f[x]=find(f[x]);
} int gcd(int kol_1,int kol_2)
{
if(kol_2==) return kol_1;
else return gcd(kol_2,kol_1%kol_2);
} int main()
{
scanf("%d%d",&n,&m);
int from,to,dis;
for(int i=;i<=m;i++)
{
scanf("%d%d%d",&from,&to,&dis);
edge_add(from,to,dis,i);
}
scanf("%d%d",&start,&end);
sort(edge+,edge+m+,cmp);
ans_max=0x7ffffff,ans_min=;
for(int v=;v<=m;v++)
{
for(int i=;i<=n;i++) f[i]=i;
minn=edge[v].dis,maxn=edge[v].dis;
for(int i=v;i<=m;i++)
{
int x=find(edge[i].from),y=find(edge[i].to);
if(x!=y)
{
f[x]=y;
maxn=max(maxn,edge[i].dis);
}
if(find(start)==find(end)) break;
}
if(find(start)==find(end))
{
if(double(maxn)/double(minn)<double(ans_max)/double(ans_min))
{
ans_max=maxn,ans_min=minn;
}
}
}
if(ans_min==) printf("IMPOSSIBLE\n");
else
{
int cur_1=gcd(ans_max,ans_min);
ans_max/=cur_1;
ans_min/=cur_1;
if(ans_min==) printf("%d\n",ans_max);
else printf("%d/%d",ans_max,ans_min);
}
return ;
}

AC日记——舒适的路线 codevs 1001 (并查集+乱搞)的更多相关文章

  1. bzoj 1050: [HAOI2006]旅行comf(codevs.cn 1001 舒适的路线) 快排+并查集乱搞

    没用的话:好像很久没发博客了,主要是懒太蒟找不到水题.我绝对没弃坑...^_^ 还用些话:本文为博主原创文章,若转载请注明原网址和作者. 进入正题: 先pa网址: bzoj :http://www.l ...

  2. 【2018百度之星初赛 B】1001并查集 1004二分 1006不等式

    1001 degree 题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=6380 并查集向图中加点,分别记录与初始度数最多的点 直接相连的点数.独立的点数 ...

  3. AC日记——接龙游戏 codevs 1051

    1051 接龙游戏  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description 给出了N个单词,已经按长度排好了序.如果 ...

  4. AC日记——逃跑的拉尔夫 codevs 1026 (搜索)

    1026 逃跑的拉尔夫  时间限制: 1 s    空间限制: 128000 KB    题目等级 : 黄金 Gold 题解       题目描述 Description   年轻的拉尔夫开玩笑地从一 ...

  5. AC日记——最优贸易 codevs 1173

    题目描述 Description [问题描述]C 国有n 个大城市和m 条道路,每条道路连接这n 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这m 条道路中有一部分为单向通行的道路 ...

  6. AC日记——香甜的黄油 codevs 2038

    2038 香甜的黄油 USACO  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Description 农夫Jo ...

  7. AC日记——地鼠游戏 codevs 1052

    1052 地鼠游戏  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解       题目描述 Description 王钢是一名学习成绩优异的学生,在平 ...

  8. AC日记——鬼谷子的钱袋 codevs 2998

    2998 鬼谷子的钱袋 2006年省队选拔赛湖南  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 大师 Master    题目描述 Description 鬼谷子非常聪明,正 ...

  9. AC日记——自然数和分解 codevs 2549

    自然数和分解 思路: 水题: 代码: #include <bits/stdc++.h> using namespace std; ][]; int main() { cin>> ...

随机推荐

  1. ASP.NET Web API 数据提供系统相关类型及其关系

  2. 功放AUX接口解析

    功放上的AUX输入端口就是音频输入端口,用来连接音频输出设备:PC机上声卡.MP3播放器.CD机等

  3. velocity merge作为工具类从web上下文和jar加载模板的两种常见情形

    很多时候,处于各种便利性或折衷或者通用性亦或是限制的原因,会借助于模板生成结果,在此介绍两种使用velocity merge的情形,第一种是和spring mvc一样,将模板放在velocityCon ...

  4. location对象及history对象

     history对象 location 是最有用的BOM对象之一,它提供了与当前窗口中加载的文档有关的信息,还提供了一些导航功能.事实上,location 对象是很特别的一个对象,因为它既是windo ...

  5. SASS语法学习

    一.嵌套 1.选择器嵌套 <header> <nav> <a href=“##”>Home</a> <a href=“##”>About&l ...

  6. jQuery源码分析-01总体架构

    1. 总体架构 1.1自调用匿名函数 self-invoking anonymous function 打开jQuery源码,首先你会看到这样的代码结构: (function( window, und ...

  7. Undefined symbols for architecture i386:和"_OBJC_CLASS_$_xx", referenced from:问题解决方法

    多个人共同操作同一个项目或拷贝项目时,经常会出现类似这样的问题: Undefined symbols for architecture i386: "_OBJC_CLASS_$_xx文件名& ...

  8. 如何创建可扩展表视图中的iOS 学习和拓展优化(有待更新)

    首先介绍老外的文章:<How To Create an Expandable Table View in iOS>这是老外用Swift实现 的,对应的老外github项目源码:https: ...

  9. [Weblogic]如何清理缓存

    背景:在开发调试或测试时,很多时候重新更新部署服务后会发现某些更新并没有体现到,还是之前的情况,也或者会出现其他错误问题,这个时候就要考虑到可能是weblogic缓存未清理引起. 清理缓存步骤如下: ...

  10. Memcache笔记04-Memcached机制深入了解

    Memcached机制深入了解 ①基于c/s架构 ,协议简单 c/s架构,此时memcached为服务器端,我们可以使用如PHP,c/c++等程序连接memcached服务器. memcached的服 ...