python3实现二叉树的遍历与递归算法解析(小结)


Posted in Python onJuly 03, 2019

1、二叉树的三种遍历方式

二叉树有三种遍历方式:先序遍历,中序遍历,后续遍历 即:先中后指的是访问根节点的顺序 eg:先序 根左右 中序 左根右 后序 左右根

遍历总体思路:将树分成最小的子树,然后按照顺序输出

python3实现二叉树的遍历与递归算法解析(小结)

1.1 先序遍历

a 先访问根节点

b 访问左节点

c 访问右节点

a(b ( d ( h ) )( e ( i ) ))( c ( f )( g )) -- abdheicfg

1.2 中序遍历

a 先访问左节点

b 访问根节点

c 访问右节点

( ( ( h ) d ) b ( ( i ) e ) ) a ( ( f ) c ( g ) ) -- hdbieafcg

1.3后序遍历

a 先访问左节点

b 访问右节点

c 访问根节点

((hd)(ie)b)(fgc)a -- hdiebfgca

2、python3实现树结构

#实现树结构的类,树的节点有三个私有属性 左指针 右指针 自身的值
class Node():

  def __init__(self,data=None):
    self._data = data
    self._left = None
    self._right = None

  def set_data(self,data):
    self._data = data

  def get_data(self):
    return self._data

  def set_left(self,node):
    self._left = node

  def get_left(self):
    return self._left

  def set_right(self,node):
    self._right = node

  def get_right(self):
    return self._right

if __name__ == '__main__':
  #实例化根节点
  root_node = Node('a')
  # root_node.set_data('a')
  #实例化左子节点
  left_node = Node('b')
  #实例化右子节点
  right_node = Node('c')
  
  #给根节点的左指针赋值,使其指向左子节点
  root_node.set_left(left_node)
  #给根节点的右指针赋值,使其指向右子节点
  root_node.set_right(right_node)

  print(root_node.get_data(),root_node.get_left().get_data(),root_node.get_right().get_data())

3、实现树的递归遍历(前 中 后 层次遍历)

下例是树的遍历算法,其中对树的类进行了优化,

#实现树结构的类,树的节点有三个私有属性 左指针 右指针 自己的值
class Node():

  def __init__(self,data =None,left=None,right = None):
    self._data = data
    self._left = left
    self._right = right


#先序遍历 遍历过程 根左右
def pro_order(tree):
  if tree == None:
    return False
  print(tree._data)
  pro_order(tree._left)
  pro_order(tree._right)

#后序遍历
def pos_order(tree):
  if tree == None:
    return False
  # print(tree.get_data())
  pos_order(tree._left)
  pos_order(tree._right)
  print(tree._data)

#中序遍历
def mid_order(tree):
  if tree == None:
    return False
  # print(tree.get_data())
  mid_order(tree._left)
  print(tree._data)
  mid_order(tree._right)


#层次遍历
def row_order(tree):
  # print(tree._data)
  queue = []
  queue.append(tree)
  while True:
    if queue==[]:
      break
    print(queue[0]._data)
    first_tree = queue[0]
    if first_tree._left != None:
      queue.append(first_tree._left)
    if first_tree._right != None:
      queue.append(first_tree._right)
    queue.remove(first_tree)

if __name__ == '__main__':

  tree = Node('A',Node('B',Node('D'),Node('E')),Node('C',Node('F'),Node('G')))
  pro_order(tree)
  mid_order(tree)
  pos_order(tree)

4、递归算法

python3实现二叉树的遍历与递归算法解析(小结)

python3实现二叉树的遍历与递归算法解析(小结)

上面两张图片是从知乎贴过来的;图1中返回后会直接返回到上一级的返回,这种想法是不全面的,较合理的返回应该是如图2 在子函数返回时应返回到调用子函数的节点,这样在执行完剩余代码再返回到上一级

如果是按照图1返回的话二叉树的遍历就不能按照上例来实现。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python中xrange和range的区别
May 13 Python
Python中DJANGO简单测试实例
May 11 Python
python3批量删除豆瓣分组下的好友的实现代码
Jun 07 Python
pandas ix &iloc &loc的区别
Jan 10 Python
浅谈python之高阶函数和匿名函数
Mar 21 Python
详解python数据结构和算法
Apr 18 Python
Python读取xlsx文件的实现方法
Jul 04 Python
详解python中*号的用法
Oct 21 Python
python实现一个点绕另一个点旋转后的坐标
Dec 04 Python
快速解决jupyter notebook启动需要密码的问题
Apr 21 Python
如何利用Python识别图片中的文字
May 31 Python
python读取excel进行遍历/xlrd模块操作
Jul 12 Python
python简单区块链模拟详解
Jul 03 #Python
python使用递归的方式建立二叉树
Jul 03 #Python
python挖矿算力测试程序详解
Jul 03 #Python
如何用Python做一个微信机器人自动拉群
Jul 03 #Python
Python中的正则表达式与JSON数据交换格式
Jul 03 #Python
python实现共轭梯度法
Jul 03 #Python
python实现微信自动回复及批量添加好友功能
Jul 03 #Python
You might like
php读取xml实例代码
2010/01/28 PHP
PHP与服务器文件系统的简单交互
2016/10/21 PHP
PHP 序列化和反序列化函数实例详解
2020/07/18 PHP
浅谈PHP无限极分类原理
2019/03/14 PHP
PHP程序员必须知道的两种日志实例分析
2020/05/14 PHP
抽出www.templatemonster.com的鼠标悬停加载大图模板的代码
2007/07/11 Javascript
JavaScript实现QueryString获取GET参数的方法
2013/07/02 Javascript
jQuery拖拽插件gridster使用指南
2015/04/21 Javascript
jQuery焦点图轮播特效代码分享(3款)
2015/09/05 Javascript
微信小程序 slider的简单实例
2017/04/19 Javascript
深究AngularJS之ui-router详解
2017/06/13 Javascript
Node.js使用Express.Router的方法
2017/11/14 Javascript
基于 Immutable.js 实现撤销重做功能的实例代码
2018/03/01 Javascript
JS实现为动态添加的元素增加事件功能示例【基于事件委托】
2018/03/21 Javascript
如何制作一个Node命令行图像识别工具
2018/12/12 Javascript
JavaScript 预解析的4种实现方法解析
2019/09/03 Javascript
学习 Vue.js 遇到的那些坑
2021/02/02 Vue.js
[10:42]Team Liquid Vs Newbee
2018/06/07 DOTA
python模拟鼠标拖动操作的方法
2015/03/11 Python
python使用BeautifulSoup分析网页信息的方法
2015/04/04 Python
python使用in操作符时元组和数组的区别分析
2015/05/19 Python
python数据结构之链表详解
2017/09/12 Python
pandas groupby 分组取每组的前几行记录方法
2018/04/20 Python
Django 使用logging打印日志的实例
2018/04/28 Python
用python编写第一个IDA插件的实例
2018/05/29 Python
python中从str中提取元素到list以及将list转换为str的方法
2018/06/26 Python
python使用Plotly绘图工具绘制水平条形图
2020/03/25 Python
Django中ajax发送post请求 报403错误CSRF验证失败解决方案
2019/08/13 Python
Python实现串口通信(pyserial)过程解析
2019/09/25 Python
在PyCharm中实现添加快捷模块
2020/02/12 Python
python SOCKET编程基础入门
2021/02/27 Python
世界上最大的餐具公司:Oneida
2016/12/17 全球购物
澳大利亚百货公司:David Jones
2018/02/08 全球购物
Zavvi荷兰:英国大型音像制品和图书游戏零售商
2018/03/22 全球购物
俄语翻译实习生的自我评价分享
2013/11/06 职场文书
2015年感恩母亲节活动方案
2015/05/04 职场文书