我是靠谱客的博主 神勇未来,这篇文章主要介绍贪心算法之最短路径问题(Dijkstra算法),现在分享给大家,希望可以做个参考。

1、问题

一个求单源最短路径的问题。给定有向带权图 G =(V, E ),
其中每条边的权是非负实数。此外,给定 V 中的一个顶点,
称为源点。现在要计算从源到所有其他各顶点的最短路径长
度,这里路径长度指路上各边的权之和。

 


2、分析

 

 


3、代码实现

1、普通C++实现
 
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream> #include <cstdio> #include <stack> #include <string> using namespace std; /* 一定要记得如果初始化矩阵的话,肯定需要一个变量保存长和宽的最大值, 如果看到权重的话,肯定是需要有个变量保存最大值的权重 */ //城市的节点数目的最大值 const int MAX_CITY_NUM = 100; //节点权值的最大值 const int MAX_POLICY = 1e7; //初始化权重矩阵 int map[MAX_CITY_NUM][MAX_CITY_NUM]; //源点到各个顶点的最短具体数组 int dist[MAX_CITY_NUM]; //下标表示当前节点

最后

以上就是神勇未来最近收集整理的关于贪心算法之最短路径问题(Dijkstra算法)的全部内容,更多相关贪心算法之最短路径问题(Dijkstra算法)内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(63)

评论列表共有 0 条评论

立即
投稿
返回
顶部