本文主要是介绍最短路径算法:迪杰克斯拉(Dijkstra)算法(基于贪心思想)【从一个顶点到其余各顶点的最短路径算法,解决的是有权图中最短路径问题】【能得出最短路径的最优解,但由于它遍历计算的节点很多,所以效率低】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Dijkstra算法是典型最短路算法,用于计算一个节点到其他所有节点的最短路径。主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止。Dijkstra算法能得出最短路径的最优解,但由于它遍历计算的节点很多,所以效率低。
Viterbi和Dijkstra算法看起来比较像,两者的区别:
-
Dijkstra算法适应范围更广。Viterbi算法用在特殊的有向无环图中,而Dijkstra算法可以用在大部分图结构中(有向无向、有环无环都可以)。
-
搜索过程类似,但搜索顺序不同。Dijkstra每步选择最短路的结点处进行搜索,而Viterbi按照拓扑顺序逐层搜索。
-
Dijkstra是基于贪心思路的,而Viterbi是一种动态规划思路。
参考资料:
最短路径算法和维特比算法、HMM假设
最短路径算法Viterbi vs Dijkstra
N-最短路径分词算法
这篇关于最短路径算法:迪杰克斯拉(Dijkstra)算法(基于贪心思想)【从一个顶点到其余各顶点的最短路径算法,解决的是有权图中最短路径问题】【能得出最短路径的最优解,但由于它遍历计算的节点很多,所以效率低】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!