python如何用Dijkstra算法实现最短路径?
admin
2023-02-14 15:20:03
0

  这篇文章主要介绍了python Dijkstra算法实现最短路径问题的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

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

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

  使用集合S记录已求得最短路径的终点K线图的跳空,初始时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:

  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

相关内容

热门资讯

德国总理:美国正在被伊朗羞辱 德国之声4月27日报道,德国总理默茨在访问一所学校时表示,在当前的持续冲突中,伊朗领导层正试图羞辱美...
理响中国|“长”歌以行,风云激... 光阴如梭,东方潮阔。这里是中国的长三角,世界的长三角。无论过去、现在还是未来,这片土地都因时代而生,...
白宫:特朗普及其国安团队开会讨... 新华社华盛顿4月27日电 美国白宫新闻秘书莱维特27日在记者会上证实,总统特朗普及其国家安全团队当天...
人民日报刊文:日本放开杀伤性武... 日本放开杀伤性武器出口推高地缘冲突风险(国际论坛)常思纯《人民日报》(2026年04月28日 第 0...
医疗保障法草案二审:明确生育保... 满足多样化健康保障需求本报记者 彭 波4月27日,医疗保障法草案二审稿提请十四届全国人大常委会第二十...
天津一景区发生自转旋翼机事故1... 澎湃新闻记者 吕新文中国民用航空华北地区管理局4月22日公布《豪客通航“10•1”天津长芦汉盐旅游区...
卡塔尔埃米尔与美国总统特朗普通... 当地时间24日,卡塔尔埃米尔塔米姆与美国总统特朗普通电话,重点就中东地区局势以及伊朗与美国谈判问题交...
男子30年前被扣押2859克黄... 澎湃新闻记者 王鑫家住辽宁省大连市的潘永嘉近日向澎湃新闻反映称,三十年前,他在大连周水子机场被盖州市...
商务部:取消反制欧盟两家金融机... 中华人民共和国商务部令二〇二六年 第1号鉴于欧盟已取消对中国两家金融机构的制裁措施,现公布《关于取消...
过去24小时共有5艘船只通过霍... 总台记者当地时间24日获悉,过去24小时内,共有5艘船只通过霍尔木兹海峡,其中包括一艘伊朗油轮。(总...