python实现Floyd算法


Posted in Python onJanuary 03, 2018

下面是用Python实现Floyd算法的代码,供大家参考,具体内容如下

# -*- coding: utf-8 -*- 
""" 
Created on Thu Jul 13 14:56:37 2017 
 
@author: linzr 
""" 
 
## 表示无穷大 
INF_val = 9999 
 
class Floyd_Path(): 
 def __init__(self, node, node_map, path_map): 
  self.node = node 
  self.node_map = node_map 
  self.node_length = len(node_map) 
  self.path_map = path_map 
  self._init_Floyd() 
  
 def __call__(self, from_node, to_node): 
  self.from_node = from_node 
  self.to_node = to_node 
  return self._format_path() 
 
 def _init_Floyd(self): 
  for k in range(self.node_length): 
   for i in range(self.node_length): 
    for j in range(self.node_length): 
     tmp = self.node_map[i][k] + self.node_map[k][j] 
     if self.node_map[i][j] > tmp: 
      self.node_map[i][j] = tmp 
      self.path_map[i][j] = self.path_map[i][k] 
       
  print '_init_Floyd is end' 
 
 
 def _format_path(self): 
  node_list = [] 
  temp_node = self.from_node 
  obj_node = self.to_node 
  print("the shortest path is: %d")%(self.node_map[temp_node][obj_node]) 
  node_list.append(self.node[temp_node]) 
  while True: 
   node_list.append(self.node[self.path_map[temp_node][obj_node]]) 
   temp_node = self.path_map[temp_node][obj_node] 
   if temp_node == obj_node: 
    break; 
   
  return node_list 
     
 
   
 
 
def set_node_map(node_map, node, node_list, path_map): 
 for i in range(len(node)): 
  ## 对角线为0 
  node_map[i][i] = 0 
 for x, y, val in node_list: 
  node_map[node.index(x)][node.index(y)] = node_map[node.index(y)][node.index(x)] = val 
  path_map[node.index(x)][node.index(y)] = node.index(y) 
  path_map[node.index(y)][node.index(x)] = node.index(x) 
 
  
if __name__ == "__main__": 
 node = ['A', 'B', 'C', 'D', 'E', 'F', 'G'] 
 node_list = [('A', 'F', 9), ('A', 'B', 10), ('A', 'G', 15), ('B', 'F', 2), 
     ('G', 'F', 3), ('G', 'E', 12), ('G', 'C', 10), ('C', 'E', 1), 
     ('E', 'D', 7)] 
 
 ## node_map[i][j] 存储i到j的最短距离 
 node_map = [[INF_val for val in xrange(len(node))] for val in xrange(len(node))] 
 ## path_map[i][j]=j 表示i到j的最短路径是经过顶点j 
 path_map = [[0 for val in xrange(len(node))] for val in xrange(len(node))] 
  
 ## set node_map 
 set_node_map(node_map, node, node_list, path_map) 
 
 
 ## select one node to obj node, e.g. A --> D(node[0] --> node[3]) 
 from_node = node.index('A') 
 to_node = node.index('E') 
 Floydpath = Floyd_Path(node, node_map, path_map) 
 path = Floydpath(from_node, to_node) 
 print path

python实现Floyd算法

运行结果为:
the shortest path is: 23
['A', 'F', 'G', 'C', 'E']

Python 相关文章推荐
Python实现快速多线程ping的方法
Jul 15 Python
浅谈python socket函数中,send与sendall的区别与使用方法
May 09 Python
Python多进程库multiprocessing中进程池Pool类的使用详解
Nov 24 Python
浅谈python日志的配置文件路径问题
Apr 28 Python
pandas修改DataFrame列名的实现方法
Feb 22 Python
详解django2中关于时间处理策略
Mar 06 Python
Linux下远程连接Jupyter+pyspark部署教程
Jun 21 Python
使用遗传算法求二元函数的最小值
Feb 11 Python
Django的ListView超详细用法(含分页paginate)
May 21 Python
Python如何实现自带HTTP文件传输服务
Jul 08 Python
爬虫代理的cookie如何生成运行
Sep 22 Python
Python实现列表拼接和去重的三种方式
Jul 02 Python
Python如何生成树形图案
Jan 03 #Python
Python爬取十篇新闻统计TF-IDF
Jan 03 #Python
Python制作词云的方法
Jan 03 #Python
Python读取Json字典写入Excel表格的方法
Jan 03 #Python
python基于ID3思想的决策树
Jan 03 #Python
python遍历文件夹下所有excel文件
Jan 03 #Python
Python将多份excel表格整理成一份表格
Jan 03 #Python
You might like
PHP中static关键字原理的学习研究分析
2011/07/18 PHP
php获取文件夹路径内的图片以及分页显示示例
2014/03/11 PHP
ThinkPHP连接数据库及主从数据库的设置教程
2014/08/22 PHP
php实现分页显示
2015/11/03 PHP
js 实现图片预加载(js操作 Image对象属性complete ,事件onload 异步加载图片)
2011/03/25 Javascript
解析javascript 实用函数的使用详解
2013/05/10 Javascript
jquery中html、val与text三者属性取值的联系与区别介绍
2013/12/29 Javascript
javascript读取Xml文件做一个二级联动菜单示例
2014/03/17 Javascript
JavaScript中创建字典对象(dictionary)实例
2015/03/31 Javascript
原生javascript实现匀速运动动画效果
2016/02/26 Javascript
很棒的Bootstrap选项卡切换效果
2016/07/01 Javascript
解析微信JS-SDK配置授权,实现分享接口
2016/12/09 Javascript
angular 用拦截器统一处理http请求和响应的方法
2017/06/08 Javascript
JS实现的加减乘除四则运算计算器示例
2017/08/09 Javascript
jQuery实现可兼容IE6的淡入淡出效果告警提示功能示例
2017/09/20 jQuery
部署vue+Springboot前后端分离项目的步骤实现
2020/05/31 Javascript
pyqt4教程之widget使用示例分享
2014/03/07 Python
python通过邮件服务器端口发送邮件的方法
2015/04/30 Python
Python的Django框架中自定义模版标签的示例
2015/07/20 Python
Python探索之创建二叉树
2017/10/25 Python
Python使用pylab库实现绘制直方图功能示例
2018/06/01 Python
使用CodeMirror实现Python3在线编辑器的示例代码
2019/01/14 Python
python 使用装饰器并记录log的示例代码
2019/07/12 Python
pandas 强制类型转换 df.astype实例
2020/04/09 Python
keras自定义回调函数查看训练的loss和accuracy方式
2020/05/23 Python
python开发入门——列表生成式
2020/09/03 Python
python 基于PYMYSQL使用MYSQL数据库
2020/12/24 Python
html5+css3实现一款注册表单实例
2013/04/17 HTML / CSS
印尼太阳百货公司网站:Matahari
2018/02/04 全球购物
法国设计制造的扫帚和刷子:Andrée Jardin
2018/12/06 全球购物
生育关怀行动实施方案
2014/03/26 职场文书
教师群众路线教育实践活动个人对照检查材料
2014/11/04 职场文书
2014个人年度工作总结
2014/12/15 职场文书
2015年会计个人工作总结
2015/04/02 职场文书
Nginx域名转发使用场景代码实例
2021/03/31 Servers
django上传文件的三种方式
2021/04/29 Python