Python实现的多叉树寻找最短路径算法示例


Posted in Python onJuly 30, 2018

本文实例讲述了Python实现的多叉树寻找最短路径算法。分享给大家供大家参考,具体如下:

多叉树的最短路径:

思想:

    传入start 和 end 两个 目标值
    1 找到从根节点到目标节点的路径
    2 从所在路径,寻找最近的公共祖先节点,
    3 对最近公共祖先根节点 拼接路径

Python代码:

# -*- coding:utf-8 -*-
import copy
#节点数据结构
class Node(object):
  # 初始化一个节点
  def __init__(self,value = None):
    self.value = value # 节点值
    self.child_list = []  # 子节点列表
  # 添加一个孩子节点
  def add_child(self,node):
    self.child_list.append(node)
# 初始化一颗测试二叉树
def init():
  '''
  初始化一颗测试二叉树:
      A
    B  C  D
   EFG    HIJ
  '''
  root = Node('A')
  B = Node('B')
  root.add_child(B)
  root.add_child(Node('C'))
  D = Node('D')
  root.add_child(D)
  B.add_child(Node('E'))
  B.add_child(Node('F'))
  B.add_child(Node('G'))
  D.add_child(Node('H'))
  D.add_child(Node('I'))
  D.add_child(Node('J'))
  return root
# 深度优先查找 返回从根节点到目标节点的路径
def deep_first_search(cur,val,path=[]):
  path.append(cur.value) # 当前节点值添加路径列表
  if cur.value == val:  # 如果找到目标 返回路径列表
    return path
  if cur.child_list == []:  # 如果没有孩子列表 就 返回 no 回溯标记
    return 'no'
  for node in cur.child_list: # 对孩子列表里的每个孩子 进行递归
    t_path = copy.deepcopy(path)  # 深拷贝当前路径列表
    res = deep_first_search(node,val,t_path)
    if res == 'no': # 如果返回no,说明找到头 没找到 利用临时路径继续找下一个孩子节点
      continue
    else :
      return res # 如果返回的不是no 说明 找到了路径
  return 'no' # 如果所有孩子都没找到 则 回溯
# 获取最短路径 传入两个节点值,返回结果
def get_shortest_path( start,end ):
  # 分别获取 从根节点 到start 和end 的路径列表,如果没有目标节点 就返回no
  path1 = deep_first_search(root, start, [])
  path2 = deep_first_search(root, end, [])
  if path1 == 'no' or path2 == 'no':
    return '无穷大','无节点'
  # 对两个路径 从尾巴开始向头 找到最近的公共根节点,合并根节点
  len1,len2 = len(path1),len(path2)
  for i in range(len1-1,-1,-1):
    if path1[i] in path2:
      index = path2.index(path1[i])
      path2 = path2[index:]
      path1 = path1[-1:i:-1]
      break
  res = path1+path2
  length = len(res)
  path = '->'.join(res)
  return '%s:%s'%(length,path)
# 主函数、程序入口
if __name__ == '__main__':
  root = init()
  res = get_shortest_path('F','I')
  print(res)

运行结果:

5:F->B->A->D->I

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python的Template使用指南
Sep 11 Python
python脚本监控docker容器
Apr 27 Python
python实现一个简单的udp通信的示例代码
Feb 01 Python
解决python super()调用多重继承函数的问题
Jun 26 Python
python面试题之列表声明实例分析
Jul 08 Python
pytorch索引查找 index_select的例子
Aug 18 Python
安装2019Pycharm最新版本的教程详解
Oct 22 Python
Python大数据之使用lxml库解析html网页文件示例
Nov 16 Python
6行Python代码实现进度条效果(Progress、tqdm、alive-progress​​​​​​​和PySimpleGUI库)
Jan 06 Python
Python实现从N个数中找到最大的K个数
Apr 02 Python
TensorFlow使用Graph的基本操作的实现
Apr 22 Python
python excel多行合并的方法
Dec 09 Python
tensorflow: variable的值与variable.read_value()的值区别详解
Jul 30 #Python
Tensorflow 实现修改张量特定元素的值方法
Jul 30 #Python
python用BeautifulSoup库简单爬虫实例分析
Jul 30 #Python
对TensorFlow的assign赋值用法详解
Jul 30 #Python
Python双向循环链表实现方法分析
Jul 30 #Python
tensorflow更改变量的值实例
Jul 30 #Python
Python使用分布式锁的代码演示示例
Jul 30 #Python
You might like
探讨PHP使用eAccelerator的API开发详解
2013/06/09 PHP
php的GD库imagettftext函数解决中文乱码问题
2015/01/24 PHP
PHP上传图片、删除图片简单实例
2016/11/12 PHP
了解jQuery技巧来提高你的代码
2010/01/08 Javascript
ExtJS 刷新后如何默认选中刷新前最后一次选中的节点
2014/04/03 Javascript
js控制iframe的高度/宽度让其自适应内容
2014/04/09 Javascript
多个checkbox被选中时如何判断是否有自己想要的
2014/09/22 Javascript
通过JS动态创建一个html DOM元素并显示
2014/10/15 Javascript
jQuery匹配文档链接并添加class的方法
2015/06/26 Javascript
js实现简洁大方的二级下拉菜单效果代码
2015/09/01 Javascript
详解微信小程序入门五: wxml文件引用、模版、生命周期
2017/01/20 Javascript
AngularJS实现的锚点楼层跳转功能示例
2018/01/02 Javascript
vue通过数据过滤实现表格合并
2020/11/30 Javascript
JavaScript实现网页动态生成表格
2020/11/25 Javascript
python基于pygame实现响应游戏中事件的方法(附源码)
2015/11/11 Python
Python简单网络编程示例【客户端与服务端】
2017/05/26 Python
Python微信企业号开发之回调模式接收微信端客户端发送消息及被动返回消息示例
2017/08/21 Python
python自动化脚本安装指定版本python环境详解
2017/09/14 Python
pandas 将list切分后存入DataFrame中的实例
2018/07/03 Python
Python实现模拟登录网易邮箱的方法示例
2018/07/05 Python
Python 3.3实现计算两个日期间隔秒数/天数的方法示例
2019/01/07 Python
python将视频转换为全字符视频
2019/04/26 Python
python解释器spython使用及原理解析
2019/08/24 Python
python面向对象之类属性和类方法案例分析
2019/12/30 Python
tf.concat中axis的含义与使用详解
2020/02/07 Python
关于Django Models CharField 参数说明
2020/03/31 Python
django 实现后台从富文本提取纯文本
2020/07/02 Python
YSL圣罗兰美妆英国官网:Yves Saint Laurent Beauty UK
2019/08/03 全球购物
了解AppleShare protocol(AppleShare协议)吗
2015/08/28 面试题
安全资金保障制度
2014/01/23 职场文书
2014年医院后勤工作总结
2014/12/06 职场文书
团拜会主持词
2015/07/04 职场文书
学雷锋广播稿大全
2015/08/19 职场文书
导游词之任弼时故居
2020/01/07 职场文书
Vue图片裁剪组件实例代码
2021/07/02 Vue.js
pandas中对文本类型数据的处理小结
2021/11/01 Python