Problem Description

XX星球有很多城市,每个城市之间有一条或多条飞行通道,但是并不是所有的路都是很安全的,每一条路有一个安全系数s,s是在 0 和 1 间的实数(包括0,1),一条从u 到 v 的通道P 的安全度为Safe(P) = s(e1)*s(e2)…*s(ek) e1,e2,ek是P 上的边 ,现在8600 想出去旅游,面对这这么多的路,他想找一条最安全的路。但是8600 的数学不好,想请你帮忙 ^_^

Input

输入包括多个测试实例,每个实例包括:<br>第一行:n。n表示城市的个数n<=1000;<br>接着是一个n*n的矩阵表示两个城市之间的安全系数,(0可以理解为那两个城市之间没有直接的通道)<br>接着是Q个8600要旅游的路线,每行有两个数字,表示8600所在的城市和要去的城市。

Output

如果8600无法达到他的目的地,输出"What a pity!",其他的输出这两个城市之间的最安全道路的安全系数,保留三位小数。

Sample Input

3
1 0.5 0.5
0.5 1 0.4
0.5 0.4 1
3
1 2
2 3
1 3 

Sample Output

0.500

0.400
0.500

思路:求一个图中的最长路,类似模版题,本来想用Dijkstra算法,但算了算时间复杂度,发现使用Floyed算法不会超时,果断使用

Source Program

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<string>
#include<cstdlib>
#include<queue>
#define INF 9999999999999999999
#define N 1001
#define MOD 1000000007
#define E 1e-12
using namespace std;
double g[N][N];
int main()
{int n,m;while(scanf("%d",&n)!=EOF){for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)scanf("%lf",&g[i][j]);for(int k=1;k<=n;k++)for(int i=1;i<=n;i++)for(int j=1;j<=n;j++)if(i!=k&&j!=i&&j!=k)if(g[i][j]<g[i][k]*g[k][j])g[i][j]=g[i][k]*g[k][j];scanf("%d",&m);for(int i=1;i<=m;i++){int x,y;scanf("%d%d",&x,&y);if(g[x][y]!=0)printf("%.3lf\n",g[x][y]);elseprintf("What a pity!\n");}}return 0;
}

Find the safest road(HDU-1596)相关推荐

  1. 有源汇有上下界最大流/最小流 配题(HDU 3157)

    因为是有源汇所以设源点为 s,汇点为 t. 有源汇有上下界最大流: 连接一条 t 指向 s 的边,容量为 INF. 通过上述步骤,现在图变成了无源汇网络. 引入超级源点 S,超级汇点 T. 连接一条 ...

  2. 杭电1596find the safest road(spfa)

    find the safest road Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Ot ...

  3. HDU1596find the safest road(floyd)

    题目链接 find the safest road Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Ja ...

  4. 最大表示法--环形字符串最大字典序(HDU 5442)

    http://acm.hdu.edu.cn/showproblem.php?pid=5442 问题概述:n个字符围成一个环,请从这个环中找出字典序最大的长度为n的字符串,输出它的起始点和方向(0顺1 ...

  5. HDU2019多校第二场 1009(HDU 6599) I Love Palindrome String(回文树(自动机)+manacher)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6599 解题思路: 回文自动机求每个本质不同的子串出现的次数,同时记录每个节点i代表的回文串第一次出现的 ...

  6. S-Nim (HDU 1536)组合博弈SG多组游戏

    S-Nim 题目链接 Problem Description Arthur and his sister Caroll have been playing a game called Nim for ...

  7. hdu 1596 find the safest road(Dijkstra)

    Problem Description XX星球有很多城市,每个城市之间有一条或多条飞行通道,但是并不是所有的路都是很安全的,每一条路有一个安全系数s,s是在 0 和 1 间的实数(包括0,1),一条 ...

  8. BestCoder25 1001.Harry and Magical Computer(hdu 5154) 解题报告

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5154 题目意思:有 n 门 processes(编号依次为1,2,...,n),然后给出 m 种关系: ...

  9. Ant Trip(HDU 3018)---多笔画问题

    题目链接 题目描述 Ant Country consist of N towns.There are M roads connecting the towns. Ant Tony,together w ...

最新文章

  1. 微软软件推送服务器,向 UWP 应用添加推送通知 - Azure Mobile Apps | Microsoft Docs
  2. delete,drop,truncate 区别
  3. STM32移植RT-Thread的串口只能接收一个字节数据的问题
  4. 神经网络入门(最通俗的理解神经网络)
  5. Redis实战(三):Redis的List、Set、Hash、sorted_set、skip list
  6. JS验证图片格式和大小并预览
  7. java指针的数组_java 指针 数组的使用
  8. jQuery data
  9. ie8 不支持 position:fixed 的简单解决办法
  10. 电话本写完了,发个1.0吧
  11. python日志(Logger)的输出
  12. Java面试:应聘Java开发工程师的基本要求是什么?
  13. 时间序列平稳性的判断
  14. Java 垃圾回收算法
  15. ACM基础题——小刘认亲
  16. LTE:PHR Power Headroom Report 功率余量上报
  17. js正则之前瞻后顾与非捕获分组
  18. 内存设置无效: 内存预留 (sched.mem.min) 应该等于内存大小 (65536)
  19. ubuntu20.04安装ROS及常见问题
  20. QT下载速度慢的解决方法

热门文章

  1. 眼花缭乱的数据库,怎样选择?给你这个书单,想学哪个学哪个
  2. 哪些数据库是行存储?哪些是列存储?有什么区别?
  3. android 键盘点击事件监听事件,Android 键盘事件触发以及监听
  4. 面试题:在日常工作中怎么做MySQL优化的?
  5. 低代码平台,JeecgBoot v3.0版本发布—新里程牌开始,迎接VUE3版本到来
  6. dubbo和mq的使用场景
  7. Spring Boot开发之流水无情(二)
  8. SpringBoot2 整合Nacos组件,环境搭建和入门案例详解
  9. Java描述设计模式(15):责任链模式
  10. ubuntu8.04安装java+eclipse+J2ME+wtk