最短路径问题 HDU 3790 双权最短路
来源:互联网 发布:钓鱼源码 编辑:程序博客网 时间:2024/06/10 22:38
最短路径问题
Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64uDescription
给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费最少的。
Input
输入n,m,点的编号是1~n,然后是m行,每行4个数 a,b,d,p,表示a和b之间有一条边,且其长度为d,花费为p。最后一行是两个数 s,t;起点s,终点。n和m为0时输入结束。
(1<n<=1000, 0<m<100000, s != t)
(1<n<=1000, 0<m<100000, s != t)
Output
输出 一行有两个数, 最短距离及其花费。
Sample Input
3 21 2 5 62 3 4 51 30 0
Sample Output
9 11
一般情况下,题目直接说XX算法问题一般考得都不是XX算法,然而这题例外。。。
这真的是一道最短路的问题,只不过是一个双权的最短路,不仅要求路径长度最短,还要求花费最少,而且路径长度是主权,花费是次权。
分析最短路算法,首先找到一个当前最短的路径lowcost[k],然后根据这条最短路以及最优子结构性质向外更新到其它点的最短路,lowcost[i]=min(lowcost[i],lowcost[k]+dis[k][i]),我们只要在
lowcost[i]==lowcost[k]+dis[k][i]的时候判断一下val[i]与val[k]+cost[k][i]的关系即可,处理方法与lowcost完全相同,只不过lowcost占主导地位。
#include <iostream>#include <cmath>#include <stdio.h>#include <string>#include <cstring>#include <map>#include <set>#include <vector>#include <stack>#include <queue>#include <iomanip>#include <algorithm>#define MAXN 1010#define INF 0x3f3f3f3fusing namespace std;int Map[MAXN][MAXN];int cost[MAXN][MAXN];int lowcost[MAXN];int val[MAXN];bool vis[MAXN];int n,m;void dijkstra(int st,int ed){ int i,j,k,Min; for(i=1; i<=n; i++)//初始化 { lowcost[i]=INF; vis[i]=false; } val[st]=0; lowcost[st]=0; for(j=0; j<n; j++)//找到当前的一条最短路 { k=-1; Min=INF; for(i=1; i<=n; i++) { if(!vis[i]&&lowcost[i]<Min) { Min=lowcost[i]; k=i; } } if(k==-1) break; vis[k]=true; for(i=1; i<=n; i++)//判断每一个点 { if(!vis[i])//如果没有被加入最短路 { if(lowcost[k]+Map[k][i]<lowcost[i])//首先判断距离 { lowcost[i]=lowcost[k]+Map[k][i]; val[i]=val[k]+cost[k][i];//费用无条件增加 } else if(lowcost[k]+Map[k][i]==lowcost[i])//其次判断费用 { if(val[k]+cost[k][i]<val[i]) val[i]=val[k]+cost[k][i]; } } } }}int main(){ int a,b,d,p,i,j; int st,ed; while(~scanf("%d%d",&n,&m)&&n&&m) { for(i=1; i<=n; i++)//初始化 for(j=1; j<=n; j++) { Map[i][j]=INF; cost[i][j]=INF; } for(i=0; i<m; i++) { scanf("%d%d%d%d",&a,&b,&d,&p); //可能会出现重边 if(Map[a][b]>d)//保留距离较短的 { Map[a][b]=Map[b][a]=d; cost[a][b]=cost[b][a]=p; } else if(Map[a][b]==d&&cost[a][b]>p)//保留费用较少的 { cost[a][b]=cost[b][a]=p; } } scanf("%d%d",&st,&ed); dijkstra(st,ed); printf("%d %d\n",lowcost[ed],val[ed]); } return 0;}
0 0
- HDU 3790-最短路径问题(双权最短路)
- 最短路径问题 HDU 3790 双权最短路
- HDU 3790 最短路径问题 双向限制最短路
- hdu 3790 最短路径问题(最短路)
- hdu 3790 最短路径问题(多权值的最短路)
- hdu 3790 最短路径问题 最短路Dijkstra
- HDU 3790 最短路径问题【最短路 dijkstra 双权值】
- 【最短路+最小费用】hdu 3790 最短路径问题
- HDU 3790 最短路径问题 (最短路变形
- HDU 3790 最短路径问题(单源最短路)
- HDU 3790 最短路径问题(dijk最短路变形)
- hdu 3790 最短路径问题(两个限制条件的最短路)
- HDU 3790 最短路径问题(迪杰斯特拉/优先队列/最短路)
- HDU 3790 最短路径问题【多关键字最短路,Dijkstra算法+spfa算法】
- 【最短路径-Dis】hdu 3790 最短路径问题
- [最短路径] HDU 2544 - 最短路
- Hud 3790 最短路径问题[基础最短路Dijkstra]
- HDOJ 3790 最短路径问题 (最短路 && Dijkstra && 双权值)
- 单链表的基本操作
- 三角形2
- bzoj4402: Claris的剑
- notes on virtio-blk driver
- 优先队列的一些使用
- 最短路径问题 HDU 3790 双权最短路
- HDU 5651xiaoxin juju needs help 带模除法逆元+有重复元素的全排列值
- hdu4031 Atack(树状数组区间更新单点求值)
- 在企业内部分发 iOS 应用程序
- Android学习:数据持久化技术(一,File & SharePreference)
- 三角形3
- Java 设计模式-适配器模式
- poj 1664[dfs]
- Hacker 学习发展流程图