python实现dijkstra最短路由算法


Posted in Python onJanuary 17, 2019

Dijkstra算法:又称迪杰斯特拉算法,迪杰斯特拉算法是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法。是从一个顶点到其余各顶点的最短路径算法,解决的是有向图中最短路径问题。迪杰斯特拉算法主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止百度百科。

注意:Dijkstra算法不能处理包含负边的图

# dijkstra算法实现,有向图和路由的源点作为函数的输入,最短路径最为输出
def dijkstra(graph,src):
 # 判断图是否为空,如果为空直接退出
 if graph is None:
 return None
 nodes = [i for i in range(len(graph))] # 获取图中所有节点
 visited=[] # 表示已经路由到最短路径的节点集合
 if src in nodes:
 visited.append(src)
 nodes.remove(src)
 else:
 return None
 distance={src:0} # 记录源节点到各个节点的距离
 for i in nodes:
 distance[i]=graph[src][i] # 初始化
 # print(distance)
 path={src:{src:[]}} # 记录源节点到每个节点的路径
 k=pre=src
 while nodes:
 mid_distance=float('inf')
 for v in visited:
  for d in nodes:
  new_distance = graph[src][v]+graph[v][d]
  if new_distance < mid_distance:
   mid_distance=new_distance
   graph[src][d]=new_distance # 进行距离更新
   k=d
   pre=v
 distance[k]=mid_distance # 最短路径
 path[src][k]=[i for i in path[src][pre]]
 path[src][k].append(k)
 # 更新两个节点集合
 visited.append(k)
 nodes.remove(k)
 print(visited,nodes) # 输出节点的添加过程
 return distance,path
if __name__ == '__main__':
 graph_list = [ [0, 2, 1, 4, 5, 1],
  [1, 0, 4, 2, 3, 4],
  [2, 1, 0, 1, 2, 4],
  [3, 5, 2, 0, 3, 3],
  [2, 4, 3, 4, 0, 1],
  [3, 4, 7, 3, 1, 0]]

 distance,path= dijkstra(graph_list, 0) # 查找从源点0开始带其他节点的最短路径
 print(distance,path)

节点的遍历过程如下:

python实现dijkstra最短路由算法

最短路径输出:

python实现dijkstra最短路由算法

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
独特的python循环语句
Nov 20 Python
Django学习笔记之Class-Based-View
Feb 15 Python
Python实现嵌套列表及字典并按某一元素去重复功能示例
Nov 30 Python
Python中装饰器高级用法详解
Dec 25 Python
python3+PyQt5+Qt Designer实现堆叠窗口部件
Apr 20 Python
python3.X 抓取火车票信息【修正版】
Jun 19 Python
Python 类的特殊成员解析
Jun 20 Python
Django urls.py重构及参数传递详解
Jul 23 Python
python函数修饰符@的使用方法解析
Sep 02 Python
Python3批量创建Crowd用户并分配组
May 20 Python
Python操作dict时避免出现KeyError的几种解决方法
Sep 20 Python
Python模拟键盘输入自动登录TGP
Nov 27 Python
Pycharm 设置默认头的图文教程
Jan 17 #Python
python实现狄克斯特拉算法
Jan 17 #Python
在PyCharm下使用 ipython 交互式编程的方法
Jan 17 #Python
python最小生成树kruskal与prim算法详解
Jan 17 #Python
解决PyCharm不运行脚本,而是运行单元测试的问题
Jan 17 #Python
在PyCharm导航区中打开多个Project的关闭方法
Jan 17 #Python
Python设计模式之模板方法模式实例详解
Jan 17 #Python
You might like
PHP音乐采集(部分代码)
2007/02/14 PHP
PHP 面向对象实现代码
2009/11/11 PHP
使用php语句将数据库*.sql文件导入数据库
2014/05/05 PHP
php+jQuery.uploadify实现文件上传教程
2014/12/26 PHP
laravel框架中表单请求类型和CSRF防护实例分析
2019/11/23 PHP
Javascript下判断是否为闰年的Datetime包
2010/10/26 Javascript
Javascript中的delete介绍
2012/09/02 Javascript
js判断字符长度以及中英文数字等
2013/12/31 Javascript
window.location的重写及判断location是否被重写
2014/09/04 Javascript
thinkphp 表名 大小写 窍门
2015/02/01 Javascript
以JavaScript来实现WordPress中的二级导航菜单的方法
2015/12/14 Javascript
jquery调整表格行tr上下顺序实例讲解
2016/01/09 Javascript
基于Node.js实现nodemailer邮件发送
2016/01/26 Javascript
jQuery实现手机自定义弹出输入框
2016/06/13 Javascript
详解webpack 如何集成第三方js库
2017/06/29 Javascript
Node.js五大应用性能技巧小结(必须收藏)
2017/08/09 Javascript
浅析为什么a=&quot;abc&quot; 不等于 a=new String(&quot;abc&quot;)
2017/10/25 Javascript
javaScript强制保留两位小数的输入数校验和小数保留问题
2018/05/09 Javascript
[08:17]Ti9 现场cosplay
2019/09/10 DOTA
Python中解析JSON并同时进行自定义编码处理实例
2015/02/08 Python
Python文档生成工具pydoc使用介绍
2015/06/02 Python
怎样使用Python脚本日志功能
2016/08/14 Python
Python实现破解猜数游戏算法示例
2017/09/25 Python
关于Django显示时间你应该知道的一些问题
2017/12/25 Python
解决新版Pycharm中Matplotlib图像不在弹出独立的显示窗口问题
2019/01/15 Python
django 通过url实现简单的权限控制的例子
2019/08/16 Python
Python常见反爬虫机制解决方案
2020/06/01 Python
HTML5 实现图片上传预处理功能
2020/02/06 HTML / CSS
H5 video poster属性设置视频封面的方法
2020/05/25 HTML / CSS
意大利在线购买隐形眼镜网站:VisionDirect.it
2019/03/18 全球购物
代码中finally中的代码会不会执行
2012/02/06 面试题
给交警的表扬信
2014/01/12 职场文书
函授毕业生自我鉴定范文
2014/03/25 职场文书
护士找工作求职信
2014/07/02 职场文书
群众路线专项整治方案
2014/10/27 职场文书
如何Python使用re模块实现okenizer
2022/04/30 Python