当前位置:主页 > 论文百科 > 论文创新 >

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏

发布时间:2016-07-10 21:02

  本文关键词:dijkstra算法,由笔耕文化传播整理发布。


1.dijkstra算法简介

Dijkstra算法是由E.W.Dijkstra于1959年提出,又叫迪杰斯特拉算法,它应用了贪心算法模式,是目前公认的最好的求解最短路径的方法。算法解决的是有向图中单个源点到其他顶点的最短路径问题,其主要特点是每次迭代时选择的下一个顶点是标记点之外距离源点最近的顶点。但由于dijkstra算法主要计算从源点到其他所有点的最短路径,所以算法的效率较低。

2.dijkstra算法基本过程

假设路网中每一个节点都有标号

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏

 是从出发点s到点t的最短路径长度;

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏

表示从s到t的最短路径中t点的前一个点。求解从出发点s到点t的最短路径算法的基本过程为:

1.      初始化。出发点设置为:

 

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏

标记起源点s,,记k = s,其他所有点设为未标记。

2.      检验从所有已标记的点k到其他直接连接的未标记的点j的距离,并设置:

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏


3.      选取下一个点。从所有未标记的点中选取 最小的点i,点i被选为最短路径中的一点,并设为已标记的。

4.      找到点i的前一点。从已经标记的点集合中找到直接连接到点i的点,并标记为 。

5.      标记点i。如果所有的点已标记,则算法结束。否则,记k = i,转到2继续。

从以上算法的步骤中可以看出 :dijkstra算法的关键部分是从未标记的点中不断地找出距离源点距离最近的点,并把改点加入到标记的点集合中,同时更新未标记的点集合中其余点到起始点的最短估计距离 。

以一个带有权值的无向图为例,用dijkstra算法分析从源点A到目标点F的最短路径。

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏


1. 用带有权值的一个矩阵w表示含有n各节点的带权无向图, 代表弧段 的权值,如果从节点 到节点 不连通,那么 ,带权值图邻接矩阵如下图所示.设置A为源点,G为目的点, 代表从节点A到有向图中其他节点 的最短路径长度。设置初始值

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏

代表标记的节点集合。

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏


2.

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏

是从A点出发求出的一条最短路径上的终止节点,令

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏


3.  修改起始节点A到集合

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏

之间的最短路径的长度值,如果d(j)+w(j,k) < d(k),那么d(k) = d(j) + w(j,k);

4. 重复步骤2、3的操作N-1次,最终得到从起始节点A到其他节点的最短路径,按照递增的顺序排列路径的长度。

3.dijkstra算法的流程图如下所示:

dijkstra算法演示_dijkstra算法例题_longshengguoji的专栏



  本文关键词:dijkstra算法,由笔耕文化传播整理发布。



本文编号:68704

资料下载
论文发表

本文链接:https://www.wllwen.com/wenshubaike/shangbiaozhuanli/68704.html


Copyright(c)文论论文网All Rights Reserved | 网站地图 |

版权申明:资料由用户a967b***提供,本站仅收录摘要或目录,作者需要删除请E-mail邮箱bigeng88@qq.com