Python二叉树的定义及常用遍历算法分析


Posted in Python onNovember 24, 2017

本文实例讲述了Python二叉树的定义及常用遍历算法。分享给大家供大家参考,具体如下:

说起二叉树的遍历,大学里讲的是递归算法,大多数人首先想到也是递归算法。但作为一个有理想有追求的程序员。也应该学学非递归算法实现二叉树遍历。二叉树的非递归算法需要用到辅助栈,算法着实巧妙,令人脑洞大开。

以下直入主题:

定义一颗二叉树,请看官自行想象其形状,

class BinNode( ):
  def __init__( self, val ):
    self.lchild = None
    self.rchild = None
    self.value = val
binNode1 = BinNode( 1 )
binNode2 = BinNode( 2 )
binNode3 = BinNode( 3 )
binNode4 = BinNode( 4 )
binNode5 = BinNode( 5 )
binNode6 = BinNode( 6 )
binNode1.lchild = binNode2
binNode1.rchild = binNode3
binNode2.lchild = binNode4
binNode2.rchild = binNode5
binNode3.lchild = binNode6

先序遍历:

'''
先序遍历二叉树
'''
def bin_tree_pre_order_traverse( root, visit_func ):
  s = Stack()
  s.push( root )
  while not s.is_empty():
    node = s.pop()
    visit_func( node )
    if node.rchild:
      s.push( node.rchild )
    if node.lchild:
      s.push( node.lchild )

中序遍历:

'''
中序遍历二叉树
'''
def bin_tree_in_order_traverse( root, visit_func ):
  s = Stack()
  node = root
  while node or not s.is_empty():
    if node:
      s.push( node )
      node = node.lchild
    else:
      node = s.pop()
      visit_func( node )
      node = node.rchild

后序遍历:

后序遍历中,要保证左孩子和右孩子都已被访问才能访问根结点,并且左孩子需在右孩子前访问,这就为流程的控制带来了难题。下面介绍两种思路。

思路一,双栈法,这种方式比较容易理解,缺点是需要两个栈。

'''
后序遍历二叉树
'''
def bin_tree_post_order_traverse( root, visit_func ):
  s1 = Stack()
  s2 = Stack()
  s1.push( root )
  while not s1.is_empty():
    node = s1.pop()
    s2.push( node )
    if node.lchild:
      s1.push( node.lchild )
    if node.rchild:
      s1.push( node.rchild )
  while not s2.is_empty():
    visit_func( s2.pop() )

思路二,要保证根结点在左孩子和右孩子访问之后才能访问,因此对于任一结点P,先将其入栈。如果P不存在左孩子和右孩子,则可以直接访问它;或者P存在左孩子或者右孩子,但是其左孩子和右孩子都已被访问过了,则同样可以直接访问该结点。若非上述两种情况,则将P的右孩子和左孩子依次入栈,这样就保证了每次取栈顶元素的时候,左孩子在右孩子前面被访问,左孩子和右孩子都在根结点前面被访问。

def bin_tree_post_order_traverse2( root, visit_func ):
  curr = root
  prev = None
  s = Stack()
  s.push( curr )
  while not s.is_empty():
    curr = s.peek()
    if ( not curr.lchild and not curr.rchild ) or ( prev and ( prev == curr.lchild or prev == curr.rchild ) ):
      visit_func( curr )
      s.pop()


 prev = curr
    else:
      if curr.rchild:
        s.push( curr.rchild )
      if curr.lchild:
        s.push( curr.lchild )

层序遍历:

def bin_tree_level_traverse( root, visit_func ):
  queue = Queue()
  queue.enqueue( root )
  while not queue.is_empty():
    node = queue.dequeue().value
    visit_func( node )
    if node.lchild:
      queue.enqueue( node.lchild )
    if node.rchild:
      queue.enqueue( node.rchild )

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

Python 相关文章推荐
python的类变量和成员变量用法实例教程
Aug 25 Python
Python列表生成器的循环技巧分享
Mar 06 Python
Python使用matplotlib绘图无法显示中文问题的解决方法
Mar 14 Python
python 对象和json互相转换方法
Mar 22 Python
Python编程在flask中模拟进行Restful的CRUD操作
Dec 28 Python
python自动发送测试报告邮件功能的实现
Jan 22 Python
python+pyqt5实现KFC点餐收银系统
Jan 24 Python
判断python对象是否可调用的三种方式及其区别详解
Jan 31 Python
Python使用sax模块解析XML文件示例
Apr 04 Python
Python + OpenCV 实现LBP特征提取的示例代码
Jul 11 Python
使用Tkinter制作信息提示框
Feb 18 Python
Python docutils文档编译过程方法解析
Jun 23 Python
详解python上传文件和字符到PHP服务器
Nov 24 #Python
Python实现矩阵转置的方法分析
Nov 24 #Python
利用Django内置的认证视图实现用户密码重置功能详解
Nov 24 #Python
利用python3随机生成中文字符的实现方法
Nov 24 #Python
Python内置函数 next的具体使用方法
Nov 24 #Python
python中WSGI是什么,Python应用WSGI详解
Nov 24 #Python
python中print()函数的“,”与java中System.out.print()函数中的“+”功能详解
Nov 24 #Python
You might like
用PHP和ACCESS写聊天室(七)
2006/10/09 PHP
codeigniter集成ucenter1.6双向通信的解决办法
2014/06/12 PHP
PHP解析RSS的方法
2015/03/05 PHP
IE中jscript/javascript的条件编译
2006/09/07 Javascript
取键盘键位ASCII码的网页
2007/07/30 Javascript
js 页面关闭前的出现提示的实现代码
2011/05/25 Javascript
javascript中数组的多种定义方法和常用函数简介
2014/05/09 Javascript
什么是cookie?js手动创建和存储cookie
2014/05/27 Javascript
javascript中CheckBox全选终极方案
2015/05/20 Javascript
jQuery实现下拉框选择图片功能实例
2015/08/08 Javascript
JavaScript常用数组算法小结
2016/02/13 Javascript
JavaScript中日期函数的相关操作知识
2016/08/03 Javascript
AngularJS包括详解及示例代码
2016/08/17 Javascript
JavaScript异步操作的几种常见处理方法实例总结
2020/05/11 Javascript
ant-design-vue按需加载的坑的解决
2020/05/14 Javascript
Vue的自定义组件不能使用click方法的解决
2020/07/28 Javascript
[01:06]欢迎来到上海,TI9
2018/08/26 DOTA
跟老齐学Python之坑爹的字符编码
2014/09/28 Python
Python简单的制作图片验证码实例
2017/05/31 Python
[原创]教女朋友学Python(一)运行环境搭建
2017/11/29 Python
python设置值及NaN值处理方法
2018/07/03 Python
Python打包方法Pyinstaller的使用
2018/10/09 Python
python3的url编码和解码,自定义gbk、utf-8的例子
2019/08/22 Python
简单瞅瞅Python vars()内置函数的实现
2019/09/27 Python
Pandas之缺失数据的实现
2021/01/06 Python
美国照明、家居装饰和家具购物网站:Bellacor
2017/09/20 全球购物
Lampegiganten丹麦:欧洲领先的照明网上商店
2018/04/25 全球购物
六十大寿答谢词
2014/01/12 职场文书
最新会计专业求职信范文
2014/01/28 职场文书
2015年教师工作总结范文
2015/03/31 职场文书
暑假打工感想
2015/08/07 职场文书
2015年店长个人工作总结
2015/10/23 职场文书
导游词之茶卡盐湖
2019/11/26 职场文书
一看就懂的MySQL的聚簇索引及聚簇索引是如何长高的
2021/05/25 MySQL
一篇文章带你学习Mybatis-Plus(新手入门)
2021/08/02 Java/Android
vue实现登陆页面开发实践
2022/05/30 Vue.js