传送门 :code[vs]  1001

思路:拿到这题的首先的思路 , 就是跑一遍最短路。

可是在尝试了一会后发现不会写,于是果断弃

尝试另外的算法。。

于是就有的以下的算法。并查集 + 乱搞(有点像最小生成树) + 贪心

总的来说, 就是先对边排一遍序, 从最小边开始找

若找到一条边未访问过(即在不同的集合),则将他们合并, 如果他们的最大速度 除以 最小速度 比已有答案小,则更新答案

如此重复。。

最后找 最大速度和最小速度的最大公约数来化简。。

ok

#include <iostream>
#include <cstdio>
#include <algorithm>
#define Max 10005
#define INF 1e7
using namespace std;
char word;
int N, M;
int father [Max], Count;
int Answer_Max = INF, Answer_Min, Maxn, Minn;
struct node
{
int from;
int to;
int dis;
}Edge [Max];
inline void AddEdge(int from, int to, int dis)
{
Count++;
Edge [Count].from = from;
Edge [Count].to = to;
Edge [Count].dis = dis;
}
bool comp (const node a, const node b)
{
return a.dis < b.dis;
}
int find (int x) // 找祖先
{
if (father [x] == x)
return x;
else return father [x] = find (father [x]);
}
inline void read (int &now)
{
now = ;
word = getchar ();
while (word < '' || word > '')
word = getchar ();
while (word >= '' && word <= '')
{
now = now * + (int)(word - '');
word = getchar ();
}
}
int Gcd (int x, int y) //找最大公约数
{
return y == ? x : Gcd (y, x % y);
}
int main()
{
read (N);
read (M);
int x, y, v;
for (int i = ; i <= M; i++)
{
read (x);
read (y);
read (v);
AddEdge (x, y, v);
}
sort (Edge + , Edge + + M, comp); // 把边排序,从最小的边开始找
int start, end;
read (start);
read (end);
for (int k = ; k <= M; k++)
{ for (int i = ; i <= N; i++) // 把每个点的 祖先初始化为本身
father [i] = i;
Minn = Edge [k].dis; // 初始化最大值 最小值为 当前扫描边的速度
Maxn = Edge [k].dis;
for (int i = k; i <= M; i++)
{
int x = find (Edge [i].from); // 找当前边的 两个点的祖先
int y = find (Edge [i].to);
if (x != y) //判断两点是否不在同一集合中 , 如果不在,将这两个点合并 , 证明此边都 已访问
{
father [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 (Answer_Max) / double (Answer_Min))
{
Answer_Max = Maxn;
Answer_Min = Minn;
}
}
if (Answer_Min == ) // 如果 答案未更新,则证明无解
cout << "IMPOSSIBLE";
else
{
int now = Gcd (Answer_Max, Answer_Min); // 因为结果要化为既约分数(即化到最简) 所以找出最大速度与最小速度的最大公约数
Answer_Max /= now; // 化简
Answer_Min /= now;
if (Answer_Min == ) //如果化简后最小的速度为0 ,则证明 最大与最小可以整除
cout << Answer_Max << endl;
else
cout << Answer_Max << "/" << Answer_Min << endl;
}
return ;
}

舒适的路线 (code[vs] 1001)的更多相关文章

  1. 舒适的路线(codevs 1001)

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

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

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

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

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

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

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

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

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

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

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

  7. [题解]codevs1001 舒适的路线

    h3 { font-family: Consolas; color: #339966 } .math { font-family: Consolas; color: gray } 题目描述 Descr ...

  8. codevs1001 舒适的路线 - 贪心 - 并查集

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

  9. [codevs1001]舒适的路线

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

随机推荐

  1. android项目--上下文菜单

    一般说到上下文菜单基本上都是长按事件,在一个控件上长按,就会弹出一个菜单. 1.创建上下文菜单: //覆盖方法,创建上下文菜单 @Override public void onCreateContex ...

  2. TableLayout中怎么填充相同的布局

    在Android界面xml文件中可以导入另一个xml文件,就能实现一个功能就是重复利用相同的xml布局 有两种方法进行处理: include引入 定义一个布局Tab_flag.xml <?xml ...

  3. SQL Server 行版本控制

    什么时候开启行版本? 当发现系统中存在大量读写阻塞的时候,就是我们开启行版本的时候了.要点:写写阻塞的场景行版本技术解决不了 开启方式: -- 设置为单用户 ALTER DATABASE MyTest ...

  4. DDD 回归具体的业务场景,Domain Model 再再重新设计

    DDD 回归具体的业务场景,Domain Model 再再重新设计 首先,把最真挚的情感送与梅西,加油! 写在前面 阅读目录: 重申业务场景 Domain Model 设计 后记 上一篇<设计窘 ...

  5. ASP.NET MVC 缓存扩展 - Donut Caching

    项目介绍 ASP.NET MVC Extensible Donut Caching brings donut caching to ASP.NET MVC 3 and later. The code ...

  6. IOS UI 第九篇: UITABLEVIEW

    学英语.所以用英文来记录笔记.   Define the dataSource:   @implementation ViewController{    NSMutableArray *dataSo ...

  7. WinDbg 命令手册

    WinDbg 命令三部曲:(一)WinDbg 命令手册   本文为 Dennis Gao 原创技术文章,发表于博客园博客,未经作者本人允许禁止任何形式的转载. 系列博文 <WinDbg 命令三部 ...

  8. 快速创建InfoPath表单

    快速创建InfoPath表单 2010年已经过去了一半了,这时候再说初识InfoPath可能会被很多人笑话,但是又有多少人真正认识InfoPath呢?无论你是刚刚 听说这个东西还是它的老相好都请同我一 ...

  9. Oracle 10g的空间管理

    一.表空间(包含表.字段.索引) 1.定义:表空间是一个逻辑概念,实质是组织数据文件的一种途径. 2.创建表空间 --创建表空间 create tablespace myspace datafile ...

  10. s​s​h​配​置​公​钥​和​私​钥​登​陆​S​e​c​u​r​e​C​R​T

    在用windows时管理linux服务器时,常会用到SecureCRT.Xshell以及开源的putty.在我工作环境大多都是采用密码认证的方式进行登录.今天对学习了些SecureCRT的密钥登录方式 ...