最短路径--Dijkstra(狄克斯特拉)算法

最短路径
路径的概念:
      在一个无权的图中,若从一顶点到另一顶点存在着一条路径,则称该路径长度为该路径上所经过的边的数目,它等于该路径上的顶点数减 1
       由于从一顶点到另一顶点可能存在着多条路径,每条路径上所经过的边数可能不同,即路径长度不同,我们把路径长度最短(即经过的边数最少)的那条路径叫做最短路径,其路径长度叫做最 短路径长度 最短距离
      对于带权的图,考虑路径上各边上的权值,则通常把一条路径上所经边的权值之和定义为该路径的 路径长度 或称 带权路径长度
       从源点到终点可能不止一条路径,把带权路径长度最短的那条路径称为 最短路径 ,其路径长度(权值之和)称为 最短路径长度 或者 最短距离
从某个源点到其它各顶点的最短路径: Dijkstra(狄克斯特拉)算法
每一对顶点之间的最短路径: Floyed(弗洛伊德)算法
Dijkstra(狄克斯特拉)算法
基本思想: 按路径长度递增的次序求得各条路径。
算法描述: 设图中所示为从源点到其余各点之间的最短路径,则在这些路径中,必然存在一条长度最短者, 在这条路径上,必定只含一条(权值最小)弧,由此,只要在所有从源点出发的弧中查找权值最小者。
长度次短者可能有两种情况:
         1.  它可能是从源点直接到该点的路径;
         2.  也可能是:从源点先到a,再从a到该点;
其余依次类推
Dijkstra 算法的时间复杂度:Dijkstra 算法中的两重循环都是关于n的,所以时间复杂度为:O(n2)。

最近我建立了个公众号,会发布一些关于网络安全的知识,以及网络安全的代码。如果大家对我的代码有疑问,也可以通过下面的公众号找到我,向我提问,我会及时回答,欢迎大家关注哦。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

leihengxin

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值