Python编程实现二叉树及七种遍历方法详解


Posted in Python onJune 02, 2017

本文实例讲述了Python实现二叉树及遍历方法。分享给大家供大家参考,具体如下:

介绍:

树是数据结构中非常重要的一种,主要的用途是用来提高查找效率,对于要重复查找的情况效果更佳,如二叉排序树、FP-树。另外可以用来提高编码效率,如哈弗曼树。

Python编程实现二叉树及七种遍历方法详解

代码:

用Python实现树的构造和几种遍历算法,虽然不难,不过还是把代码作了一下整理总结。实现功能:

① 树的构造
② 递归实现先序遍历、中序遍历、后序遍历
③ 堆栈实现先序遍历、中序遍历、后序遍历
④ 队列实现层次遍历

#coding=utf-8
class Node(object):
  """节点类"""
  def __init__(self, elem=-1, lchild=None, rchild=None):
    self.elem = elem
    self.lchild = lchild
    self.rchild = rchild
class Tree(object):
  """树类"""
  def __init__(self):
    self.root = Node()
    self.myQueue = []
  def add(self, elem):
    """为树添加节点"""
    node = Node(elem)
    if self.root.elem == -1: # 如果树是空的,则对根节点赋值
      self.root = node
      self.myQueue.append(self.root)
    else:
      treeNode = self.myQueue[0] # 此结点的子树还没有齐。
      if treeNode.lchild == None:
        treeNode.lchild = node
        self.myQueue.append(treeNode.lchild)
      else:
        treeNode.rchild = node
        self.myQueue.append(treeNode.rchild)
        self.myQueue.pop(0) # 如果该结点存在右子树,将此结点丢弃。
  def front_digui(self, root):
    """利用递归实现树的先序遍历"""
    if root == None:
      return
    print root.elem,
    self.front_digui(root.lchild)
    self.front_digui(root.rchild)
  def middle_digui(self, root):
    """利用递归实现树的中序遍历"""
    if root == None:
      return
    self.middle_digui(root.lchild)
    print root.elem,
    self.middle_digui(root.rchild)
  def later_digui(self, root):
    """利用递归实现树的后序遍历"""
    if root == None:
      return
    self.later_digui(root.lchild)
    self.later_digui(root.rchild)
    print root.elem,
  def front_stack(self, root):
    """利用堆栈实现树的先序遍历"""
    if root == None:
      return
    myStack = []
    node = root
    while node or myStack:
      while node:           #从根节点开始,一直找它的左子树
        print node.elem,
        myStack.append(node)
        node = node.lchild
      node = myStack.pop()      #while结束表示当前节点node为空,即前一个节点没有左子树了
      node = node.rchild         #开始查看它的右子树
  def middle_stack(self, root):
    """利用堆栈实现树的中序遍历"""
    if root == None:
      return
    myStack = []
    node = root
    while node or myStack:
      while node:           #从根节点开始,一直找它的左子树
        myStack.append(node)
        node = node.lchild
      node = myStack.pop()      #while结束表示当前节点node为空,即前一个节点没有左子树了
      print node.elem,
      node = node.rchild         #开始查看它的右子树
  def later_stack(self, root):
    """利用堆栈实现树的后序遍历"""
    if root == None:
      return
    myStack1 = []
    myStack2 = []
    node = root
    myStack1.append(node)
    while myStack1:          #这个while循环的功能是找出后序遍历的逆序,存在myStack2里面
      node = myStack1.pop()
      if node.lchild:
        myStack1.append(node.lchild)
      if node.rchild:
        myStack1.append(node.rchild)
      myStack2.append(node)
    while myStack2:             #将myStack2中的元素出栈,即为后序遍历次序
      print myStack2.pop().elem,
  def level_queue(self, root):
    """利用队列实现树的层次遍历"""
    if root == None:
      return
    myQueue = []
    node = root
    myQueue.append(node)
    while myQueue:
      node = myQueue.pop(0)
      print node.elem,
      if node.lchild != None:
        myQueue.append(node.lchild)
      if node.rchild != None:
        myQueue.append(node.rchild)
if __name__ == '__main__':
  """主函数"""
  elems = range(10)      #生成十个数据作为树节点
  tree = Tree()     #新建一个树对象
  for elem in elems:
    tree.add(elem)      #逐个添加树的节点
  print '队列实现层次遍历:'
  tree.level_queue(tree.root)
  print '\n\n递归实现先序遍历:'
  tree.front_digui(tree.root)
  print '\n递归实现中序遍历:'
  tree.middle_digui(tree.root)
  print '\n递归实现后序遍历:'
  tree.later_digui(tree.root)
  print '\n\n堆栈实现先序遍历:'
  tree.front_stack(tree.root)
  print '\n堆栈实现中序遍历:'
  tree.middle_stack(tree.root)
  print '\n堆栈实现后序遍历:'
  tree.later_stack(tree.root)

总结:

树的遍历主要有两种,一种是深度优先遍历,像前序、中序、后序;另一种是广度优先遍历,像层次遍历。在树结构中两者的区别还不是非常明显,但从树扩展到有向图,到无向图的时候,深度优先搜索和广度优先搜索的效率和作用还是有很大不同的。

深度优先一般用递归,广度优先一般用队列。一般情况下能用递归实现的算法大部分也能用堆栈来实现。

我印象中是有递归构造树的方法,却一直想不出该怎么构造。后来仔细想了一下,递归思想有点类似深度优先算法,而树的构造应该是广度优先的。如果用递归的话一定要有个终止条件,例如规定树深等。不然构造出来的树会偏向左单子树或者右单子树。所以一般树的构造还是应该用队列比较好。

以上说的不够严谨,有错误之处,欢迎指正!

更多关于Python相关内容可查看本站专题:《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

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

Python 相关文章推荐
python根据给定文件返回文件名和扩展名的方法
Mar 27 Python
讲解Python中运算符使用时的优先级
May 14 Python
python开发环境PyScripter中文乱码问题解决方案
Sep 11 Python
Flask框架的学习指南之用户登录管理
Nov 20 Python
Pytorch 实现自定义参数层的例子
Aug 17 Python
Python正则表达式学习小例子
Mar 03 Python
解决Pytorch自定义层出现多Variable共享内存错误问题
Jun 28 Python
Python内存泄漏和内存溢出的解决方案
Sep 26 Python
详解scrapy内置中间件的顺序
Sep 28 Python
Django中使用Celery的方法步骤
Dec 07 Python
python函数超时自动退出的实操方法
Dec 28 Python
Python使用Opencv打开笔记本电脑摄像头报错解问题及解决
Jun 21 Python
Python递归函数定义与用法示例
Jun 02 #Python
matplotlib绘制符合论文要求的图片实例(必看篇)
Jun 02 #Python
Python 爬虫图片简单实现
Jun 01 #Python
Python 通过URL打开图片实例详解
Jun 01 #Python
git使用.gitignore设置不生效或不起作用问题的解决方法
Jun 01 #Python
python 内置函数filter
Jun 01 #Python
python读取二进制mnist实例详解
May 31 #Python
You might like
php inc文件使用的风险和注意事项
2013/11/12 PHP
php数组查找函数总结
2014/11/18 PHP
php中删除数组的第一个元素和最后一个元素的函数
2015/03/07 PHP
Zend Framework创建自己的动作助手详解
2016/03/05 PHP
Zend Framework框架实现类似Google搜索分页效果
2016/11/25 PHP
JQuery 弹出框定位实现方法
2010/12/02 Javascript
jQuery contains过滤器实现精确匹配使用方法
2013/04/12 Javascript
jquery实现的蓝色二级导航条效果代码
2015/08/24 Javascript
JS实现的自定义网页拖动类
2015/11/06 Javascript
Bootstrap Chart组件使用教程
2016/04/28 Javascript
jQuery+CSS3文字跑马灯特效的简单实现
2016/06/25 Javascript
微信小程序 MD5加密登录密码详解及实例代码
2017/01/12 Javascript
详解使用fetch发送post请求时的参数处理
2017/04/05 Javascript
小程序scroll-view组件实现滚动的示例代码
2018/09/20 Javascript
vscode配置vue下的es6规范自动格式化详解
2019/03/20 Javascript
详解js根据百度地图提供经纬度计算两点距离
2019/05/13 Javascript
[01:27:44]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Aster BO3 第一场 1月24日
2021/03/11 DOTA
Python和Java进行DES加密和解密的实例
2018/01/09 Python
python实现求两个字符串的最长公共子串方法
2018/07/20 Python
python 含子图的gif生成时内存溢出的方法
2019/07/07 Python
python网络编程之多线程同时接受和发送
2019/09/03 Python
Python matplotlib绘制饼状图功能示例
2019/09/10 Python
使用django和vue进行数据交互的方法步骤
2019/11/11 Python
pytorch 数据处理:定义自己的数据集合实例
2019/12/31 Python
pycharm运行程序时看不到任何结果显示的解决
2020/02/21 Python
解决Jupyter notebook中.py与.ipynb文件的import问题
2020/04/21 Python
python实现飞船大战
2020/04/24 Python
使用HTML5原生对话框元素并轻松创建模态框组件
2019/03/06 HTML / CSS
Fossil美国官网:化石手表、手袋、首饰及配饰
2019/02/17 全球购物
希腊香水和化妆品购物网站:Parfimo.gr
2019/10/03 全球购物
应聘教师自荐信
2013/10/12 职场文书
公司门卫管理制度
2014/02/01 职场文书
火锅店创业计划书范文
2014/02/02 职场文书
北京颐和园导游词
2015/01/30 职场文书
Django对接elasticsearch实现全文检索的示例代码
2021/08/02 Python
Java完整实现记事本代码
2022/06/16 Java/Android