我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python中怎么利用Dijkstra算法求最短路径

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python中怎么利用Dijkstra算法求最短路径

python中怎么利用Dijkstra算法求最短路径,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

  从某源点到其余各顶点的最短路径

  Dijkstra算法可用于求解图中某源点到其余各顶点的最短路径。假设G={V,{E}}是含有n个顶点的有向图,以该图中顶点v为源点,使用Dijkstra算法求顶点v到图中其余各顶点的最短路径的基本思想如下:

  使用集合S记录已求得最短路径的终点,初始时S={v}。

  选择一条长度最小的最短路径,该路径的终点w属于V-S,将w并入S,并将该最短路径的长度记为Dw。

  对于V-S中任一顶点是s,将源点到顶点s的最短路径长度记为Ds,并将顶点w到顶点s的弧的权值记为Dws,若Dw+Dws

  则将源点到顶点s的最短路径长度修改为Dw+Ds=ws。

  重复执行2和3,知道S=V。

  为了实现算法,

  使用邻接矩阵Arcs存储有向网,当i=j时,Arcs[i][j]=0;当i!=j时,若下标为i的顶点到下标为j的顶点有弧且弧的权值为w,则Arcs[i][j]=w,否则Arcs[i][j]=float(‘inf’)即无穷大。

  使用Dist存储源点到每一个终点的最短路径长度。

  使用列表Path存储每一条最短路径中倒数第二个顶点的下标。

  使用flag记录每一个顶点是否已经求得最短路径,在思想中即是判断顶点是属于V集合,还是属于V-S集合。

  代码实现

  #构造有向图Graph

  class Graph:

  def __init__(self,graph,labels): #labels为标点名称

  self.Arcs=graph

  self.VertexNum=graph.shape[0]

  self.labels=labels

  def Dijkstra(self,Vertex,EndNode): #Vertex为源点,EndNode为终点

  Dist=[[] for i in range(self.VertexNum)] #存储源点到每一个终点的最短路径的长度

  Path=[[] for i in range(self.VertexNum)] #存储每一条最短路径中倒数第二个顶点的下标

  flag=[[] for i in range(self.VertexNum)] #记录每一个顶点是否求得最短路径

  index=0

  #初始化

  while index

  Dist[index]=self.Arcs[Vertex][index]

  flag[index]=0

  if self.Arcs[Vertex][index]

  Path[index]=Vertex

  else:

  Path[index]=-1 #表示从顶点Vertex到index无路径

  index+=1

  flag[Vertex]=1

  Path[Vertex]=0

  Dist[Vertex]=0

  index=1

  while index

  MinDist=float('inf')

  j=0

  while j

  if flag[j]==0 and Dist[j]

  tVertex=j #tVertex为目前从V-S集合中找出的距离源点Vertex最断路径的顶点

  MinDist=Dist[j]

  j+=1

  flag[tVertex]=1

  EndVertex=0

  MinDist=float('inf') #表示无穷大,若两点间的距离小于MinDist说明两点间有路径

  #更新Dist列表,符合思想中第三条

  while EndVertex

  if flag[EndVertex]==0:

  if self.Arcs[tVertex][EndVertex]

  tVertex]+self.Arcs[tVertex][EndVertex]

  Dist[EndVertex]=Dist[tVertex]+self.Arcs[tVertex][EndVertex]

  Path[EndVertex]=tVertex

  EndVertex+=1

  index+=1

  vertex_endnode_path=[] #存储从源点到终点的最短路径

  return Dist[EndNode],start_end_Path(Path,Vertex,EndNode,vertex_endnode_path)

  #根据本文上述定义的Path递归求路径

  def start_end_Path(Path,start,endnode,path):

  if start==endnode:

  path.append(start)

  else:无锡妇科医院哪家好 http://www.xasgfk.cn/

  path.append(endnode)

  start_end_Path(Path,start,Path[endnode],path)

  return path

  if __name__=='__main__':

  #float('inf')表示无穷

  graph=np.array([[0,6,5,float('inf'),float('inf'),float('inf')],

  [float('inf'),0,2,8,float('inf'),float('inf')],

  [float('inf'),float('inf'),0,float('inf'),3,float('inf')],

  [float('inf'),float('inf'),7,0,float('inf'),9],

  [float('inf'),float('inf'),float('inf'),float('inf'),0,9],

  [float('inf'),float('inf'),float('inf'),float('inf'),0]])

  G=Graph(graph,labels=['a','b','c','d','e','f'])

  start=input('请输入源点')

  endnode=input('请输入终点')

  dist,path=Dijkstra(G,G.labels.index(start),G.labels.index(endnode))

  Path=[]

  for i in range(len(path)):

  Path.append(G.labels[path[len(path)-1-i]])

  print('从顶点{}到顶点{}的最短路径为:\n{}\n最短路径长度为:{}'.format(start,endnode,Path,dist))

  输出结果如下:

  请输入源点

  a

  请输入终点

  f

  从顶点a到顶点f的最短路径为:

  ['a', 'c', 'e', 'f']

  最短路径长度为:17

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网行业资讯频道,感谢您对编程网的支持。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python中怎么利用Dijkstra算法求最短路径

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python中怎么利用Dijkstra算法求最短路径

python中怎么利用Dijkstra算法求最短路径,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。  从某源点到其余各顶点的最短路径  Dijkstra算法可用
2023-06-02

Java如何利用Dijkstra和Floyd分别求取图的最短路径

小编给大家分享一下Java如何利用Dijkstra和Floyd分别求取图的最短路径,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1 最短路径的概述在生活中,图形结
2023-06-29

python中怎么利用Dijkstra算法规划机器人路径

今天就跟大家聊聊有关python中怎么利用Dijkstra算法规划机器人路径,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、算法原理如图所示,Dijkstra算法要解决的是一个有向
2023-06-20

Java如何利用遗传算法求解最短路径

这篇“Java如何利用遗传算法求解最短路径”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java如何利用遗传算法求解最短路径
2023-07-01

python最短路径算法怎么选择

小编给大家分享一下python最短路径算法怎么选择,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!说明1、解决任意两个节点之间的最短距离,用Floyd。2、解决单源最短路径问题,有负边时用Bellman-Ford,无负边时用
2023-06-20

python中有哪些最短路径算法

这期内容当中小编将会给大家带来有关python中有哪些最短路径算法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、Bellman-Ford 算法Bellman-Ford算法用于求解单源最短路径问题。算法
2023-06-15

matlab最短路径算法怎么应用

在MATLAB中,可以使用Graph and Digraph对象来实现最短路径算法。首先,你需要创建一个Graph对象,然后通过添加边来定义图的结构。然后,你可以使用内置的最短路径函数来计算两个节点之间的最短路径。下面是一个使用MATLAB
2023-10-07

Python和Matlab怎么实现蚂蚁群算法求解最短路径

这篇文章主要介绍“Python和Matlab怎么实现蚂蚁群算法求解最短路径”,在日常操作中,相信很多人在Python和Matlab怎么实现蚂蚁群算法求解最短路径问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”P
2023-06-29

C#图表算法之最短路径怎么实现

本篇内容主要讲解“C#图表算法之最短路径怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#图表算法之最短路径怎么实现”吧!从一个顶点到达另一个顶点的成本最小的路径。我们采用一个一般性的模
2023-06-30

怎么使用c语言动态规划求解最短路径

在C语言中使用动态规划求解最短路径,可以按照以下步骤进行:1. 定义一个二维数组来表示图中各个节点之间的距离。假设有n个节点,则可以定义一个n×n的二维数组dist[][],其中dist[i][j]表示节点i到节点j的距离。2. 初始化di
2023-08-18

怎么在python中利用pathlib构建路径

怎么在python中利用pathlib构建路径?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。python主要应用领域有哪些1、云计算,典型应用OpenStack
2023-06-14

Python中怎么利用os.listdir方法判断相关路径是否为文件

这期内容当中小编将会给大家带来有关Python中怎么利用os.listdir方法判断相关路径是否为文件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Python判断是否为文件在Python os.list
2023-06-17

怎么在python中使用os.path方法解析路径

这篇文章给大家介绍怎么在python中使用os.path方法解析路径,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。python有哪些常用库python常用的库:1.requesuts;2.scrapy;3.pillow
2023-06-14

在Java中怎么利用蒙特卡洛算法求圆周率

在Java中怎么利用蒙特卡洛算法求圆周率?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1946年,美国拉斯阿莫斯国家实验室的三位科学家John von Neum
2023-05-31

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录