Dijkstra算法是典型最短路算法,用于计算一个节点到其他所有节点的最短路径。主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止。Dijkstra算法能得出最短路径的最优解,但由于它遍历计算的节点很多,所以效率低。
Viterbi和Dijkstra算法看起来比较像,两者的区别:
-
Dijkstra算法适应范围更广。Viterbi算法用在特殊的有向无环图中,而Dijkstra算法可以用在大部分图结构中(有向无向、有环无环都可以)。
-
搜索过程类似,但搜索顺序不同。Dijkstra每步选择最短路的结点处进行搜索,而Viterbi按照拓扑顺序逐层搜索。
-
Dijkstra是基于贪心思路的,而Viterbi是一种动态规划思路。
参考资料:
最短路径算法和维特比算法、HMM假设
最短路径算法Viterbi vs Dijkstra
N-最短路径分词算法