算法学习心得之一----Dijikstra算法

算法学习心得之一----Dijikstra算法–超详细

在这里插入图片描述
这个算法的目的在于,求出从某个起点到其它所有点的最短距离。
在算法运行完毕之后,相当于生成了这样一个表格:

在这里插入图片描述
第一列是每一个顶点,第二列是距离A的最短距离,第三列是这条最短路径上到达目的点之前走过的顶点。
它是如何生成的呢?
为便于理解,先假设从A到其它顶点距离为无穷。

在这里插入图片描述

首先,从A点出发

在这里插入图片描述

算法的一步,只计算相邻的点,可以看到A到B和D的距离分别为6和1,将数据存入表格中,在这里插入图片描述
注意,为了防止重复计算,我们将A点存入已访问集合,
然后找到列表中距离最小值,也就是A-C距离1,从C点出发,再重复一次之前的操作,
在这里插入图片描述
从图中可以看到DE=1,DB=2,那么ADB=1+2=3<AB=6,,ADE=1+1=2<无穷,,这个时候就可以更新表格了,

在这里插入图片描述
同时,将D存入已访问列表,这个时候在剩下的三个点中,找到距离A最近的点,也就是E,重复之前的操作,直到遍历完成。
最终就得到了
在这里插入图片描述
从表中我们可以找到每一个点距离A的最短距离,并且只要根据第三列的前一个点,就能读出路径,
例如A到C的距离最短为7,前一个定点为E,到E的最短距离为2,上一个定点为D,AD最短距离为1,上一个顶点为A,
这样一条A-D-E-D的路径就读出来了。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值