一心想学习算法,很少去真正静下心来去研究,前几天趁着周末去了解了最短路径的资料,用python写了一个最短路径算法。算法是基于带权无向图去寻找两个点之间的最短路径,数据存储用邻接矩阵记录。首先画出一幅无向图如下,标出各个节点之间的权值。

其中对应索引:

A ——> 0

B ——> 1

C ——> 2

D ——>3

E ——> 4

F ——> 5

G ——> 6

邻接矩阵表示无向图:

算法思想是通过Dijkstra算法结合自身想法实现的。大致思路是:从起始点开始,搜索周围的路径,记录每个点到起始点的权值存到已标记权值节点字典A,将起始点存入已遍历列表B,然后再遍历已标记权值节点字典A,搜索节点周围的路径,如果周围节点存在于表B,比较累加权值,新权值小于已有权值则更新权值和来源节点,否则什么都不做;如果不存在与表B,则添加节点和权值和来源节点到表A,直到搜索到终点则结束。

这时最短路径存在于表A中,得到终点的权值和来源路径,向上递推到起始点,即可得到最短路径,下面是代码:

  1. # -*-coding:utf-8 -*-
  2. class DijkstraExtendPath():
  3. def __init__(self, node_map):
  4. self.node_map = node_map
  5. self.node_length = len(node_map)
  6. self.used_node_list = []
  7. self.collected_node_dict = {}
  8. def __call__(self, from_node, to_node):
  9. self.from_node = from_node
  10. self.to_node = to_node
  11. self._init_dijkstra()
  12. return self._format_path()
  13. def _init_dijkstra(self):
  14. self.used_node_list.append(self.from_node)
  15. self.collected_node_dict[self.from_node] = [0, -1]
  16. for index1, node1 in enumerate(self.node_map[self.from_node]):
  17. if node1:
  18. self.collected_node_dict[index1] = [node1, self.from_node]
  19. self._foreach_dijkstra()
  20. def _foreach_dijkstra(self):
  21. if len(self.used_node_list) == self.node_length - 1:
  22. return
  23. for key, val in self.collected_node_dict.items(): # 遍历已有权值节点
  24. if key not in self.used_node_list and key != to_node:
  25. self.used_node_list.append(key)
  26. else:
  27. continue
  28. for index1, node1 in enumerate(self.node_map[key]): # 对节点进行遍历
  29. # 如果节点在权值节点中并且权值大于新权值
  30. if node1 and index1 in self.collected_node_dict and self.collected_node_dict[index1][0] > node1 + val[0]:
  31. self.collected_node_dict[index1][0] = node1 + val[0] # 更新权值
  32. self.collected_node_dict[index1][1] = key
  33. elif node1 and index1 not in self.collected_node_dict:
  34. self.collected_node_dict[index1] = [node1 + val[0], key]
  35. self._foreach_dijkstra()
  36. def _format_path(self):
  37. node_list = []
  38. temp_node = self.to_node
  39. node_list.append((temp_node, self.collected_node_dict[temp_node][0]))
  40. while self.collected_node_dict[temp_node][1] != -1:
  41. temp_node = self.collected_node_dict[temp_node][1]
  42. node_list.append((temp_node, self.collected_node_dict[temp_node][0]))
  43. node_list.reverse()
  44. return node_list
  45. def set_node_map(node_map, node, node_list):
  46. for x, y, val in node_list:
  47. node_map[node.index(x)][node.index(y)] = node_map[node.index(y)][node.index(x)] = val
  48. if __name__ == "__main__":
  49. node = ['A', 'B', 'C', 'D', 'E', 'F', 'G']
  50. node_list = [('A', 'F', 9), ('A', 'B', 10), ('A', 'G', 15), ('B', 'F', 2),
  51. ('G', 'F', 3), ('G', 'E', 12), ('G', 'C', 10), ('C', 'E', 1),
  52. ('E', 'D', 7)]
  53. node_map = [[0 for val in xrange(len(node))] for val in xrange(len(node))]
  54. set_node_map(node_map, node, node_list)
  55. # A -->; D
  56. from_node = node.index('A')
  57. to_node = node.index('D')
  58. dijkstrapath = DijkstraPath(node_map)
  59. path = dijkstrapath(from_node, to_node)
  60. print path

运行结果:

Python实现无向图最短路径的更多相关文章

  1. [Vijos 2024]无向图最短路径

    Description 无向图最短路径问题,是图论中最经典也是最基础的问题之一.本题我们考虑一个有 $n$ 个结点的无向图 $G$.$G$ 是简单完全图,也就是说 $G$ 中没有自环,也没有重边,但任 ...

  2. Java A*算法搜索无向图最短路径

    网上看了很多别人写的A*算法,都是针对栅格数据进行处理,每次向外扩展都是直接八方向或者四方向,这样利于理解.每次移动当前点,gCost也可以直接设置成横向10斜向14. 但是当我想处理一个连续的数据集 ...

  3. Python 图_系列之基于<链接表>实现无向图最短路径搜索

    图的常用存储方式有 2 种: 邻接炬阵 链接表 邻接炬阵的优点和缺点都很明显.优点是简单.易理解,对于大部分图结构而言,都是稀疏的,使用炬阵存储空间浪费就较大. 链接表的存储相比较邻接炬阵,使用起来更 ...

  4. 四大算法解决最短路径问题(Dijkstra+Bellman-ford+SPFA+Floyd)

    什么是最短路径问题? 简单来讲,就是用于计算一个节点到其他所有节点的最短路径. 单源最短路算法:已知起点,求到达其他点的最短路径. 常用算法:Dijkstra算法.Bellman-ford算法.SPF ...

  5. 数据结构与算法系列研究七——图、prim算法、dijkstra算法

    图.prim算法.dijkstra算法 1. 图的定义 图(Graph)可以简单表示为G=<V, E>,其中V称为顶点(vertex)集合,E称为边(edge)集合.图论中的图(graph ...

  6. 《算法》第四章部分程序 part 16

    ▶ 书中第四章部分程序,包括在加上自己补充的代码,Dijkstra 算法求有向 / 无向图最短路径,以及所有顶点对之间的最短路径 ● Dijkstra 算法求有向图最短路径 package packa ...

  7. Python绘制拓扑图(无向图)、有向图、多重图。最短路径计算

    前言: 数学中,“图论”研究的是定点和边组成的图形. 计算机中,“网络拓扑”是数学概念中“图”的一个子集.因此,计算机网络拓扑图也可以由节点(即顶点)和链路(即边)来进行定义和绘制. 延伸: 无向图 ...

  8. 最短路径算法的实现(dijskstra):Python

    dijskstra最短路径算法步骤: 输入:图G=(V(G),E(G))有一个源顶点S和一个汇顶点t,以及对所有的边ij属于E(G)的非负边长出cij. 输出:G从s到t的最短路径的长度. 第0步:从 ...

  9. Python数模笔记-NetworkX(3)条件最短路径

    1.带有条件约束的最短路径问题 最短路径问题是图论中求两个顶点之间的最短路径问题,通常是求最短加权路径. 条件最短路径,指带有约束条件.限制条件的最短路径.例如,顶点约束,包括必经点或禁止点的限制:边 ...

随机推荐

  1. BZOJ.3638.CF172 k-Maximum Subsequence Sum(模拟费用流 线段树)

    题目链接 各种zz错误..简直了 /* 19604kb 36292ms 题意:选$k$段不相交的区间,使其权值和最大. 朴素线段树:线段树上每个点维护O(k)个信息,区间合并时O(k^2),总O(mk ...

  2. socket 远程命令

    # -*- coding: utf-8 -*- # 斌彬电脑 from socket import * import subprocess server = socket(AF_INET, SOCK_ ...

  3. C# 设计模式速记

    设计模式分三种类型,共23种: 行为型:规定了对象之间交互的方式:行为模式定义系统内对象间的通信,以及复杂程序中的流程控制. 结构型:规定了如何组织类和对象:结构型模式可以将一组对象组合成更大的结构, ...

  4. js常用事件

    为了便于使读者更好地运用js事件,就把常用事件大致分为以下几种: a. 表单元素事件,在表单元素中生效 onfocus  ------获取焦点 onblur -------失去焦点 onsubmit ...

  5. MyEclipse设置文件的编码格式

    在MyEclipse中复制properties文件的时候,发现一个问题,在EditPlus中打开文件中文可以正常显示,并且是UTF-8的编码格式. 但是将这个文件复制到MyEclipse中再打开时,中 ...

  6. mui 列表项左右滑删除功能升级(仿微信左滑 点击删除后出现确认删除)

    mui 列表项左右滑删除功能升级(仿微信左滑 点击删除后出现确认删除) 2018-06-19更新显示样式

  7. [Android Pro] Android P版本 新功能介绍和兼容性处理(三)Android Studio 3.0 ~ 3.2 其他特性

    cp : https://blog.csdn.net/yi_master/article/details/80067198 1:JAVA8特性支持 1)Base64.java 在升级到as3.0之后, ...

  8. 移动电源、3G路由拆机

    这款电源4400mAh,淘宝也就八十元左右,可以作为无线路由使用,可以插3G网卡,总的来说还算不错,关键是外观精美,网上一堆和华美A100那样的,可惜实在太丑,这款外观虽然漂亮,但是和一百多的相比不支 ...

  9. 微信支付WxpayAPI_php_v3 错误修改

    微信sdk:WxpayAPI_php_v3 这是下载压缩包的目录结构. https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=11_1 ce ...

  10. mod_wsgi的工作模式和配置

    Openstack所有提供API接口的服务都是python web server,而其本身性能很弱,目前已经将它们配置到了apache上.但对于如何设置mod_wsgi的参数,我一直没有好好去阅读其文 ...