HDOJ 1596 find the safest road ((最短路变形) Dijkstra SPFA)

2023-12-08 21:18

本文主要是介绍HDOJ 1596 find the safest road ((最短路变形) Dijkstra SPFA),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

find the safest road

Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 9081    Accepted Submission(s): 3193


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

Output
如果86无法达到他的目的地,输出"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
注 - 此题为:  HDOJ 1596  find the safest road   (最长路(最短路变形) Dijkstra && SPFA)

说明:    由于寻找最安全道路,越大越安全,Dijkstra && SPFA 寻找最大路径

       安全度计算:安全度为Safe(P) = s(e1)*s(e2)…*s(ek) e1,e2,ek是P 上的边 

已AC代码:(Dijkstra)

#include<cstdio>
#define max(x,y) (x>y?x:y)
#define INF 0xfffffff
int n,vis[1010];
double map[1010][1010],d[1010];void Dijkstra(int s)  //模板变形 
{int i,j;for(i=1;i<=n;++i){vis[i]=0;d[i]=0;  // 0可以理解为那两个城市之间没有直接的通道 }d[s]=1;while(1){int j=-1;for(i=1;i<=n;++i){if(!vis[i]&&(j==-1||d[i]>d[j])) // 找较大者 j=i;}if(j==-1)break;vis[j]=1;for(i=1;i<=n;++i){d[i]=max(d[i],d[j]*map[j][i]); // 找较大者 }}
}int main()
{int i,j,Q,a,b;while(scanf("%d",&n)!=EOF){for(i=1;i<=n;++i)for(j=1;j<=n;++j)scanf("%lf",&map[i][j]);scanf("%d",&Q);for(i=0;i<Q;++i){scanf("%d%d",&a,&b);Dijkstra(a);if(d[b]==0)printf("What a pity!\n");elseprintf("%.3f\n",d[b]);}}return 0;
}


已AC代码:(SPFA

#include<cstdio>
#include<cstring>
#include<queue>
#define MAX 1005
#define INF 0x3f3f3f
using namespace std;struct Edge{int from,to;double vel;int next;
};
Edge edge[MAX*MAX];   // 不能太小 
int head[MAX*MAX],vis[MAX];
double dist[MAX];
int n,cnt;void addedge(int u,int v,double w)
{Edge E={u,v,w,head[u]};edge[cnt]=E;head[u]=cnt++;
}void SPFA(int st)  // 模板 
{queue<int>Q;memset(dist,0,sizeof(dist));memset(vis,0,sizeof(vis));Q.push(st);vis[st]=1;dist[st]=1;while(!Q.empty()){int u=Q.front();Q.pop();vis[u]=0;for(int i=head[u];i!=-1;i=edge[i].next){int v=edge[i].to;if(dist[v]<dist[u]*edge[i].vel)  // 变为求最大 {dist[v]=dist[u]*edge[i].vel;if(vis[v]==0){vis[v]=1;Q.push(v);}}}}
}int main()
{int i,j,st,ed;while(scanf("%d",&n)!=EOF){cnt=0;memset(head,-1,sizeof(head));double w;for(i=1;i<=n;++i)for(j=1;j<=n;++j){scanf("%lf",&w);addedge(i,j,w);}int N;scanf("%d",&N);while(N--){scanf("%d%d",&st,&ed);SPFA(st);if(dist[ed]==0)printf("What a pity!\n");elseprintf("%.3f\n",dist[ed]);}}return 0;
}

这篇关于HDOJ 1596 find the safest road ((最短路变形) Dijkstra SPFA)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/471350

相关文章

csu(背包的变形题)

题目链接 这是一道背包的变形题目。好题呀 题意:给n个怪物,m个人,每个人的魔法消耗和魔法伤害不同,求打死所有怪物所需的魔法 #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>//#include<u>#include<map

hdu3389(阶梯博弈变形)

题意:有n个盒子,编号1----n,每个盒子内有一些小球(可以为空),选择一个盒子A,将A中的若干个球移到B中,满足条件B  < A;(A+B)%2=1;(A+B)%3=0 这是阶梯博弈的变形。 先介绍下阶梯博弈: 在一个阶梯有若干层,每层上放着一些小球,两名选手轮流选择一层上的若干(不能为0)小球从上往下移动,最后一次移动的胜出(最终状态小球都在地面上) 如上图所示,小球数目依次为

poj 1511 Invitation Cards(spfa最短路)

题意是给你点与点之间的距离,求来回到点1的最短路中的边权和。 因为边很大,不能用原来的dijkstra什么的,所以用spfa来做。并且注意要用long long int 来存储。 稍微改了一下学长的模板。 stack stl 实现代码: #include<stdio.h>#include<stack>using namespace std;const int M

poj 3259 uva 558 Wormholes(bellman最短路负权回路判断)

poj 3259: 题意:John的农场里n块地,m条路连接两块地,w个虫洞,虫洞是一条单向路,不但会把你传送到目的地,而且时间会倒退Ts。 任务是求你会不会在从某块地出发后又回来,看到了离开之前的自己。 判断树中是否存在负权回路就ok了。 bellman代码: #include<stdio.h>const int MaxN = 501;//农场数const int

poj 1502 MPI Maelstrom(单源最短路dijkstra)

题目真是长得头疼,好多生词,给跪。 没啥好说的,英语大水逼。 借助字典尝试翻译了一下,水逼直译求不喷 Description: BIT他们的超级计算机最近交货了。(定语秀了一堆词汇那就省略吧再见) Valentine McKee的研究顾问Jack Swigert,要她来测试一下这个系统。 Valentine告诉Swigert:“因为阿波罗是一个分布式共享内存的机器,所以它的内存访问

uva 10801(乘电梯dijkstra)

题意: 给几个电梯,电梯0 ~ n-1分别可以到达很多层楼。 换乘电梯需要60s时间。 问从0层到target层最小的时间。 解析: 将进入第0层的电梯60s也算上,最后减。 坑点是如果target为0输出0。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algori

poj 3159 (spfa差分约束最短路) poj 1201

poj 3159: 题意: 每次给出b比a多不多于c个糖果,求n最多比1多多少个糖果。 解析: 差分约束。 这个博客讲差分约束讲的比较好: http://www.cnblogs.com/void/archive/2011/08/26/2153928.html 套个spfa。 代码: #include <iostream>#include <cstdio>#i

hdu 3790 (单源最短路dijkstra)

题意: 每条边都有长度d 和花费p,给你起点s 终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费最少的。 解析: 考察对dijkstra的理解。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstrin

poj 3169 spfa 差分约束

题意: 给n只牛,这些牛有些关系。 ml个关系:fr 与 to 牛间的距离要小于等于 cost。 md个关系:fr 与 to 牛间的距离要大于等于 cost。 隐含关系: d[ i ] <= d[ i + 1 ] 解析: 用以上关系建图,求1-n间最短路即可。 新学了一种建图的方法。。。。。。 代码: #include <iostream>#include

poj 3255 次短路(第k短路) A* + spfa 或 dijkstra

题意: 给一张无向图,求从1到n的次短路。 解析: A* + spfa 或者 dijkstra。 详解见上一题:http://blog.csdn.net/u013508213/article/details/46400189 本题,spfa中,stack超时,queue的效率最高,priority_queue次之。 代码: #include <iostream>#i