Dijkstra是典型最短路径算法,计算一个起始节点到路径中其他所有节点的最短路径的算法和思想.在一些专业课程中如数据结构,图论,运筹学等都有介绍.其思想是一种基础的求最短路径的算法,通过基础思想的变化可以解决很多复杂问题,如导航线路,动态规划等. Dijkstra 算法思想介绍 如下图是一个多节点,多路径图.下面以该图为例子讲解dijkstra算法寻找最短路径的过程. 以A点为起始点,求A点到其他点 B C D E F 5个点的最短路径,最后得出A到其他点的最短路径. 因为要求A到其他5个点的
一.相关定义 最短路径:从图中的某个顶点出发到达另外一个顶点的所经过的边的权重和最小的一条路径. 地位:Dijkstra算法是很有代表性的最短路算法,在很多专业课程中都作为基本内容有详细的介绍,如数据结构.图论.运筹学等等. 缺陷:若有一个带负权回路的图(即一个不存在最短路径的图),Dijkstra算法无法检测出这个问题. 时间复杂度:O(n2),若进行堆优化,可降为O(n*logn). 二.算法描述 主要变量如下: int n 表示有n个点,从1~n标号 int s,t s为源点,t为终