博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU - 3790 最短路径问题(Dijkstra)
阅读量:6325 次
发布时间:2019-06-22

本文共 2484 字,大约阅读时间需要 8 分钟。

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3790

#include 
#include
#include
#define MAX 10000005#define N 1005using namespace std;/**************************************************************************************************************** 题意:在最短路径的基础上,输出花费最小的那个路径 思路: 1,dijkstra找最短路径 2,在每次更新路径长度的同时更新花费即可****************************************************************************************************************/int visit[N]; //用来判断是非在特殊路径集合点内int dist[N],cost[N];int a[N][N],V[N][N];int dijkstra(int start,int End,int n){ for(int i = 1;i <= n;i ++){ dist[i]=a[start][i]; cost[i]=V[start][i]; } memset(visit,0,sizeof(visit)); dist[start]=0; //cost[start]=0; visit[start]=1; for(int i = 1;i < n;i ++){ int id=1,ansN=MAX; for(int j = 1;j <= n;j ++){ if(!visit[j] && dist[j] < ansN){ //在S集合外找出最小路径点(即非特殊路径) ansN=dist[j]; id=j; } } visit[id]=1; for(int j = 1;j <= n;j ++){ //以找到的最小路径点为最优解进行动态更新(非特殊路径集合点内遍历) if(!visit[j] && a[id][j] < MAX){ if(dist[j] > dist[id]+a[id][j]){ dist[j]=dist[id]+a[id][j]; cost[j]=cost[id]+V[id][j]; //更新花费 } else if(dist[j] == dist[id]+a[id][j]){ if(cost[j] > cost[id]+V[id][j]) cost[j]=cost[id]+V[id][j]; //更新花费 } } } //if(id == End) return 0; }}int main(){ int n,m; while(scanf("%d%d",&n,&m) != EOF) { if(n == 0 && m == 0) break; for(int i = 1;i <= n;i ++){ for(int j = 1;j <= n;j ++){ a[i][j]=MAX; V[i][j]=MAX; } dist[i]=MAX; cost[i]=MAX; } //memset(dist,MAX,sizeof(dist)); int A,B,C,D; for(int i = 1;i <= m;i ++){ scanf("%d%d%d%d",&A,&B,&C,&D); if(C < a[A][B]){ a[A][B]=a[B][A]=C; V[A][B]=V[B][A]=D; } else if(C == a[A][B]){ if(D < V[A][B]) V[A][B]=V[B][A]=D; } } int Start,End; cin>>Start>>End; dijkstra(Start,End,n); cout<
<<" "<
<

 

转载于:https://www.cnblogs.com/Jstyle-continue/p/6351991.html

你可能感兴趣的文章
js判断函数是否存在、判断是否为函数
查看>>
动态sql
查看>>
UVA 10564 Paths through the Hourglass[DP 打印]
查看>>
洛谷P1119 灾后重建[Floyd]
查看>>
将图片二进制流上传到服务器
查看>>
Struts2标签
查看>>
Linux命令 -- 查看系统版本的各种方法
查看>>
activemq安全设置 设置admin的用户名和密码
查看>>
[Python基础]Python中remove,del和pop的区别
查看>>
HBase 的表结构
查看>>
Android 信号处理面面观 之 信号定义、行为和来源
查看>>
windows下的 gvim - su'blime text 的使用
查看>>
一个状态机的实现
查看>>
Linux在应用层读写寄存器的方法
查看>>
【转】 Class.forName()用法及与new区别 详解
查看>>
ubuntu 删除自带软件的方法
查看>>
复杂可编程逻辑器件CPLD的基本结构
查看>>
mybatis下的分页,支持所有的数据库
查看>>
Spring AOP中级——应用场景
查看>>
扩展Microsoft Graph数据结构(开放扩展)
查看>>