优草派 > Python

如何用python实现最短路径?有这几种方法

陈立鑫         优草派

有很多正在学习python的小伙伴问:如何使用python来实现最短路径呀?有什么办法没。那么本篇章我们主要来介绍介绍使用python在图的最短路径问题,包括Dijkstra算法和Floyd算法,并用Python代码实现。

如何用python实现最短路径?有这几种方法

用python 实现最短路径的方法具体有下面这三个方法:

(一)SPFA算法:用数组dis记录每个结点的最短路径估计值。

(二)迪杰斯特拉算法:声明一个数组dis来保存源点到各个顶点的最短距离;

(三)弗洛伊德算法:在有向图中求解点与点之间最短路径;

最短路径问题(python实现)

开发者解决最短路径问题: 

(一)SPFA算法

(二)迪杰斯特拉算法(Dijkstra算法)

(三)弗洛伊德算法(Floyd算法)

第一种算法:

SPFA这种算法是求解单源最短路径问题的一种算法,有时候我们也把SPFA算法也称为 Moore-Bellman-Ford 算法。它的原理是对图进行V-1次松弛操作,得到所有可能的最短路径。

SPFA算法是优于迪科斯彻算法主要原因是因为边的权值可以为负数、实现简单,不过缺点是时间复杂度过高,高达 O(VE)。但算法可以进行若干种优化,提高了效率。

第二种算法:

Dijkstra算法

算法的思路

开发者声明一个数组dis来保存源点到各个顶点的最短距离和一个保存已经找到了最短路径的顶点的集合:Q

首先,原点s的路径权重被赋为0(dis[s]=0)。如果对于顶点s存在能直接到达的边(s,m),那么就把dis[m]设为w(s, m),且同时把所有其他(s不能直接到达的)顶点的路径长度设为无穷大。初始时,集合T只有顶点s。

然后从dis数组中选择最小值,这个值就是源点s到该值对应的顶点的最短路径,并且把该点加入到Q中,此时完成一个顶点,再看看开发者新加入的顶点是否可以到达其他顶点并且看看通过该顶点到达其他点的路径长度是否比源点直接到达短,如果是,那么就替换这些顶点在dis中的值,然后,又从dis中找出最小值,重复上述动作,直到Q中包含了图的所有顶点。

第三种算法:

Floyd算法

原理:

Floyd算法(弗洛伊德算法)是一种在有向图中求最短路径的算法。它是一种求解有向图中点与点之间最短路径的算法。

用在拥有负权值的有向图中求解最短路径(不过不能包含负权回路)

流程:

有向图中的每一个节点X,对于图中过的2点A和B,

如果有Dis(AX)+ Dis(XB)< Dis(AB),那么使得Dis(AB)=Dis(AX)+Dis(XB)。

当所有的节点X遍历完后,AB的最短路径就求出来了。

  • 微信好友

  • 朋友圈

  • 新浪微博

  • QQ空间

  • 复制链接

取消
5天短视频训练营
新手入门剪辑课程,零基础也能学
分享变现渠道,助你兼职赚钱
限时特惠:0元
立即抢
新手剪辑课程 (精心挑选,简单易学)
第一课
新手如何学剪辑视频? 开始学习
第二课
短视频剪辑培训班速成是真的吗? 开始学习
第三课
不需要付费的视频剪辑软件有哪些? 开始学习
第四课
手机剪辑app哪个好? 开始学习
第五课
如何做短视频剪辑赚钱? 开始学习
第六课
视频剪辑接单网站APP有哪些? 开始学习
第七课
哪里可以学短视频运营? 开始学习
第八课
做短视频运营需要会什么? 开始学习
【原创声明】凡注明“来源:优草派”的文章,系本站原创,任何单位或个人未经本站书面授权不得转载、链接、转贴或以其他方式复制发表。否则,本站将依法追究其法律责任。

客服热线:0731-85127885

湘ICP备19005950号-1  

工商营业执照信息

违法和不良信息举报

举报电话:0731-85127885 举报邮箱:tousu@csai.cn

优草派  版权所有 © 2024