舒适的线路

Time Limit: 1 Sec  Memory Limit: 256 MB

题目连接

http://www.codevs.cn/problem/1001/

Description

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

Input

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

Output

如果景点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

HINT

N(1<N≤500)

M(0<M≤5000)

Vi在int范围内

题意

题解:

用kruskal来找就行

枚举使用的边数量,枚举最小边,然后搞一搞就好……
最后使用gcd来搞定分数,然后这道题就解决了~

代码:

  1. //qscqesze
  2. #include <cstdio>
  3. #include <cmath>
  4. #include <cstring>
  5. #include <ctime>
  6. #include <iostream>
  7. #include <algorithm>
  8. #include <set>
  9. #include <vector>
  10. #include <sstream>
  11. #include <queue>
  12. #include <typeinfo>
  13. #include <fstream>
  14. #include <map>
  15. typedef long long ll;
  16. using namespace std;
  17. //freopen("D.in","r",stdin);
  18. //freopen("D.out","w",stdout);
  19. #define sspeed ios_base::sync_with_stdio(0);cin.tie(0)
  20. #define maxn 200001
  21. #define mod 10007
  22. #define eps 1e-9
  23. //const int inf=0x7fffffff; //无限大
  24. const int inf=0x3f3f3f3f;
  25. /*
  26. inline ll read()
  27. {
  28. int x=0,f=1;char ch=getchar();
  29. while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
  30. while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
  31. return x*f;
  32. }
  33. int buf[10];
  34. inline void write(int i) {
  35. int p = 0;if(i == 0) p++;
  36. else while(i) {buf[p++] = i % 10;i /= 10;}
  37. for(int j = p-1; j >=0; j--) putchar('0' + buf[j]);
  38. printf("\n");
  39. }
  40. */
  41. //**************************************************************************************
  42. inline ll read()
  43. {
  44. int x=,f=;char ch=getchar();
  45. while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
  46. while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
  47. return x*f;
  48. }
  49. struct node
  50. {
  51. int x,y,z;
  52. };
  53. node a[maxn];
  54. int fa[maxn];
  55. bool cmp(node a,node b)
  56. {
  57. return a.z<b.z;
  58. }
  59. int fi(int x)
  60. {
  61. if(x!=fa[x])
  62. return fi(fa[x]);
  63. return x;
  64. }
  65. void un(int x,int y)
  66. {
  67. x=fi(x);
  68. y=fi(y);
  69. if(x!=y)
  70. fa[y]=x;
  71. }
  72. int gcd(int x,int y)
  73. {
  74. return y==?x:gcd(y,x%y);
  75. }
  76.  
  77. int main()
  78. {
  79. int n,m,s,t;
  80. n=read(),m=read(),s=read(),t=read();
  81. for(int i=;i<m;i++)
  82. cin>>a[i].x>>a[i].y>>a[i].z;
  83. sort(a,a+n,cmp);
  84. double mi=inf;
  85. int ans[];
  86. ans[]=-;
  87. ans[]=-;
  88. for(int i=;i<m;i++)
  89. {
  90. for(int j=;j<n+;j++)
  91. fa[j]=j;
  92. for(int j=i;j<m;j++)
  93. {
  94. un(a[j].x,a[j].y);
  95. if(fi(s)==fi(t))
  96. {
  97. if(mi*a[i].z>=a[j].z*1.0)
  98. {
  99. mi=a[j].z*1.0/a[i].z;
  100. ans[]=a[i].z;
  101. ans[]=a[j].z;
  102.  
  103. }
  104. }
  105. }
  106. }
  107. if(ans[]==-)
  108. cout<<"IMPOSSIBLE"<<endl;
  109. else
  110. {
  111. cout<<ans[]<<" "<<ans[]<<endl;
  112. int x=gcd(ans[],ans[]);
  113. ans[]/=x;
  114. ans[]/=x;
  115. if(ans[]%ans[]==)
  116. cout<<ans[]/ans[]<<endl;
  117. else
  118. cout<<ans[]<<"/"<<ans[]<<endl;
  119. }
  120. }

codevs 1001 舒适的线路 kruskal/gcd的更多相关文章

  1. 求最大边/最小边的比值最小的路径 codevs 1001 舒适的路线

    codevs 1001 舒适的路线 2006年  时间限制: 2 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond   题目描述 Description Z小镇是一个景色宜人 ...

  2. Codevs 1001 舒适的路线 2006年 NOIP全国联赛提高组

    1001 舒适的路线 2006年 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description Z小镇是一个景色宜人的地方,吸引来自各地的观 ...

  3. codevs 1001 舒适的路线(Kruskal)

    传送门 Description Z小镇是一个景色宜人的地方,吸引来自各地的观光客来此旅游观光.Z小镇附近共有N(1<N≤500)个景点(编号为1,2,3,…,N),这些景点被M(0<M≤5 ...

  4. codevs 1001 舒适的路线 (并查集)

    题目描述 Description Z小镇是一个景色宜人的地方,吸引来自各地的观光客来此旅游观光. Z小镇附近共有 N(<N≤)个景点(编号为1,,,…,N),这些景点被M(<M≤)条道路连 ...

  5. CODEVS 1001 舒适的路线

    思路:先按照速度大小对边排序,再枚举最终路径中的速度最大值,并查集,更新答案 #include<iostream> #include<vector> #include<a ...

  6. AC日记——舒适的路线 codevs 1001 (并查集+乱搞)

    1001 舒适的路线 2006年  时间限制: 2 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Description Z小镇是 ...

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

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

  8. 舒适的路线(codevs 1001)

    题目描述 Description Z小镇是一个景色宜人的地方,吸引来自各地的观光客来此旅游观光.Z小镇附近共有N(1<N≤500)个景点(编号为1,2,3,…,N),这些景点被M(0<M≤ ...

  9. codevs1001 舒适的线路

    题目描述 Description Z小镇是一个景色宜人的地方,吸引来自各地的观光客来此旅游观光.Z小镇附近共有N(1<N≤500)个景点(编号为1,2,3,…,N),这些景点被M(0<M≤ ...

随机推荐

  1. ASP.NET MVC 5使用Filter过滤Action参数防止sql注入,让你代码安全简洁

    在开发程序的过程中,稍微不注意就会隐含有sql注入的危险.今天我就来说下,ASP.NET mvc 5使用Filter过滤Action参数防止sql注入,让你代码安全简洁.不用每下地方对参数的值都进行检 ...

  2. RestTemplate中文乱码问题(spring-web3.0.7版本)

    从网上找的方法: 方法一: //resttemplate乱码问题 //3.1.X以上版本使用 // restTemplate.getMessageConverters().add(0, StringH ...

  3. 金融数据分析 - 利用 Tushare Pro 平台 获取金融数据

    Tushare金融大数据开放社区 免费提供各类金融数据和区块链数据 , 助力智能投资与创新型投资. 详见 https://tushare.pro/

  4. robotframework-ride多次运行,有时候不显示日志信息

    解决方法: 修改"C:\Python27\lib\site-packages\robotide\contrib\testrunner\testrunner.py"文件pop方法中  ...

  5. Effective STL 学习笔记: Item 22 ~ 24

    Effective STL 学习笔记: Item 22 ~ 24 */--> div.org-src-container { font-size: 85%; font-family: monos ...

  6. 选择性卸载eclipse安装过的工具

    我们有时候需要卸载eclipse中之前安装的一些工具,而不想全部删除,那就可以采取下面的方式: 打开eclipse,Help->About Eclipse->Installation De ...

  7. 聊一聊FE面试那些事【原创】

    最近公司由于业务的扩展.技术的延伸需要招一批有能力的小伙伴加入,而我有幸担任"技术面试官"的角色前前后后面试了不下50多位候选人,如同见证了50多位前端开发者的经历一样,在面试的过 ...

  8. hbase 性能调

    一. HBase的通用优化 1 高可用 在 HBase 中 Hmaster 负责监控 RegionServer 的生命周期,均衡 RegionServer 的负载,如果 Hmaster 挂掉了,那么整 ...

  9. cent7.0 mysql 修改端口

    如何查看mysql 默认端口号和修改端口号 2015-03-19 17:42:18 1. 登录mysql [root@test /]# mysql -u root -p Enter password: ...

  10. python安装pip和使用pip安装Python库类比如pip安装beautifulsoup4

    初学Python时,看到很多不懂得东西,比如 pip, 是python 包管理工具,pip是easy_install的取代. Distribute是对标准库disutils模块的增强,我们知道disu ...