数学建模社区-数学中国

标题: Dijkstra最短路径算法演示 [打印本页]

作者: 蒙萌    时间: 2009-8-26 22:23
标题: Dijkstra最短路径算法演示
算法介绍:
; o6 N4 E* A" m1 ^Dijkstra算法的基本思路是:假设每个点都有一对标号 (dj, pj),其中dj是从起源点s到点j的最短路径的长度 (从顶点到其本身的最短路径是零路(没有弧的路),其长度等于零);pj则是从s到j的最短路径中j点的前一点。求解从起源点s到点j的最短路径算法的基本过程如下:( H3 u1 @: u- g7 r; V
  1) 初始化。起源点设置为:① ds=0, ps为空;② 所有其他点: di=∞, pi=?;③ 标记起源点s,记k=s,其他所有点设为未标记的。
7 I$ a7 C! k* L1 @: T  2) 检验从所有已标记的点k到其直接连接的未标记的点j的距离,并设置:
$ x9 U& V6 _9 A! T; j- ndj=min[dj, dk+lkj]3 E/ R- ^: a$ }1 T
式中,lkj是从点k到j的直接连接距离。( m  i0 S$ Z, X( \: e
  3) 选取下一个点。从所有未标记的结点中,选取dj 中最小的一个i:. O7 I) I, V  Q) R- P
di=min[dj, 所有未标记的点j]
& H; l. e' L: t点i就被选为最短路径中的一点,并设为已标记的。
, }+ c5 g4 k4 I  4) 找到点i的前一点。从已标记的点中找到直接连接到点i的点j*,作为前一点,设置:$ y( v* ~# H, y0 F* F7 r& i
i=j*- l% i. m( E/ [6 q3 s
  5) 标记点i。如果所有点已标记,则算法完全推出,否则,记k=i,转到2) 再继续
作者: 蒙萌    时间: 2009-8-26 22:24
希望大家指证
作者: alazyrabbit    时间: 2009-8-26 22:47
可以使用Find-Union Set,更简单!
作者: troops123    时间: 2010-7-13 19:33
太好啦,,哈哈哈哈哈
作者: troops123    时间: 2010-7-13 19:33
太好啦  哈哈哈哈哈
作者: troops123    时间: 2010-7-13 19:35
太好啦  哈哈哈哈哈
作者: troops123    时间: 2010-7-13 19:45
太好啦  哈哈哈哈哈
作者: troops123    时间: 2010-7-13 19:51
太好啦  哈哈哈哈哈
作者: alair009    时间: 2012-1-26 11:04
支持一,下楼主辛苦了11904353806607842189515399431061318562933323172351902062712511545587355567747319
作者: 婷婷玉立    时间: 2012-1-29 20:29
可以看看运筹学
作者: 婷婷玉立    时间: 2012-1-29 20:30
或者是模糊数学,
作者: 婷婷玉立    时间: 2012-1-29 20:30
对童靴应该有帮助
作者: 婷婷玉立    时间: 2012-1-29 20:31
赞同,╭(╯3╰)╮
作者: 婷婷玉立    时间: 2012-1-29 20:31
呦呦呦呦╭(╯3╰)╮
作者: 婷婷玉立    时间: 2012-1-29 20:31

作者: 婷婷玉立    时间: 2012-1-29 20:32

作者: 婷婷玉立    时间: 2012-1-29 20:32

作者: 婷婷玉立    时间: 2012-1-29 20:32

作者: 婷婷玉立    时间: 2012-1-29 20:33

作者: scutyf    时间: 2012-2-4 13:55
婷婷玉立 发表于 2012-1-29 20:29 ; r- y4 [) Z% E) |3 q. C: L
可以看看运筹学
2 j" @) P/ R( b# Z5 ~7 I
运筹学里面有这个内容?????哪个版本的运筹啊
作者: Asgard    时间: 2012-2-4 14:22
这东西不需要吧
作者: a6070933    时间: 2012-2-4 22:16
先谢楼主了
作者: wssl103050    时间: 2012-5-31 11:37
呵呵  分享一下挺好的额
作者: 刘伶广场    时间: 2013-5-3 19:59

作者: 我是男神    时间: 2015-7-29 09:59
taihaola           hahahahhahahahahah9 d$ \. s* O2 R7 ?1 h( B& A





欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5