Python二叉树的遍历操作示例【前序遍历,中序遍历,后序遍历,层序遍历】


Posted in Python onDecember 24, 2018

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

# coding:utf-8
"""
@ encoding: utf-8
@ author: lixiang
@ email: lixiang_cn@foxmail.com
@ python_version: 2
@ time: 2018/4/11 0:09
@ more_info:
二叉树是有限个元素的集合,该集合或者为空、或者有一个称为根节点(root)的元素及两个互不相交的、分别被称为左子树和右子树的二叉树组成。
1 二叉树的每个结点至多只有二棵子树(不存在度大于2的结点),二叉树的子树有左右之分,次序不能颠倒。
2 二叉树的第i层至多有2^{i-1}个结点
3 深度为k的二叉树至多有2^k-1个结点;
4 对任何一棵二叉树T,如果其终端结点数为N0,度为2的结点数为N2,则N0=N2+1
5 度是二叉树分支树,对于二叉树而言有0,1,2三种取值
不管是前中后序遍历,都是在当前规则下,无路可走时,输出根结点。
"""
class TreeNode(object):
  def __init__(self, x, left=None, right=None):
    self.val = x
    self.left = left
    self.right = right
def pre_traverse(root):
  """
  根左右
  :param root:
  :return:
  """
  if not root:
    return
  print root.val,
  pre_traverse(root.left)
  pre_traverse(root.right)
def mid_travese(root):
  """
  左根右
  :param root:
  :return:
  """
  if not root:
    return
  mid_travese(root.left)
  print root.val,
  mid_travese(root.right)
def after_travese(root):
  """
  左右根
  :param root:
  :return:
  """
  if not root:
    return
  after_travese(root.left)
  after_travese(root.right)
  print root.val,
def level_travese(root):
  if not root:
    return
  queue = []
  queue.append(root)
  while queue:
    cur = queue.pop(0)
    print cur.val,
    if cur.left:
      queue.append(cur.left)
    if cur.right:
      queue.append(cur.right)
def depth(root):
  if not root:
    return 0
  left = depth(root.left)
  right = depth(root.right)
  return max(left, right) + 1
if __name__ == '__main__':
  """
  tree是一个表示树根节点的对象
  前序遍历 1 2 4 5 8 9 11 3 6 7 10
  中序遍历 4 2 8 5 11 9 1 6 3 10 7
  后序遍历 4 8 11 9 5 2 6 10 7 3 1
  层序遍历 1 2 3 4 5 6 7 8 9 10 11
  深度 5
  """
  tree = TreeNode(1, TreeNode(2, TreeNode(4), TreeNode(5, TreeNode(8), TreeNode(9, left=TreeNode(11)))), TreeNode(3, TreeNode(6), TreeNode(7, left=TreeNode(10))))
  print("\n前序遍历")
  pre_traverse(tree)
  print("\n中序遍历")
  mid_travese(tree)
  print("\n后序遍历")
  after_travese(tree)
  print("\n层序遍历")
  level_travese(tree)
  print("\n深度")
  print(depth(tree))

运行结果:

前序遍历
1 2 4 5 8 9 11 3 6 7 10
中序遍历
4 2 8 5 11 9 1 6 3 10 7
后序遍历
4 8 11 9 5 2 6 10 7 3 1
层序遍历
1 2 3 4 5 6 7 8 9 10 11
深度
5

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

Python 相关文章推荐
python中的对象拷贝示例 python引用传递
Jan 23 Python
教你用Python写安卓游戏外挂
Jan 11 Python
PyQt5实现无边框窗口的标题拖动和窗口缩放
Apr 19 Python
python字符串string的内置方法实例详解
May 14 Python
正确理解Python中if __name__ == '__main__'
Jan 24 Python
python的移位操作实现详解
Aug 21 Python
django ListView的使用 ListView中获取url中的参数值方式
Mar 27 Python
如何基于python对接钉钉并获取access_token
Apr 21 Python
Python 如何实现访问者模式
Jul 28 Python
python 使用csv模块读写csv格式文件的示例
Dec 02 Python
python爬虫scrapy框架的梨视频案例解析
Feb 20 Python
Python数据可视化之基于pyecharts实现的地理图表的绘制
Jun 10 Python
详解Python进阶之切片的误区与高级用法
Dec 24 #Python
Python数据抓取爬虫代理防封IP方法
Dec 23 #Python
python3爬虫怎样构建请求header
Dec 23 #Python
windows下搭建python scrapy爬虫框架步骤
Dec 23 #Python
python构建基础的爬虫教学
Dec 23 #Python
Flask之请求钩子的实现
Dec 23 #Python
python爬虫获取新浪新闻教学
Dec 23 #Python
You might like
php5.3 废弃函数小结
2010/05/16 PHP
PHP filter_var() 函数 Filter 函数
2012/04/25 PHP
PHP SPL使用方法和他的威力
2013/11/12 PHP
PHP无限极分类函数的实现方法详解
2017/04/15 PHP
PHP基于pdo的数据库操作类【可支持mysql、sqlserver及oracle】
2018/05/21 PHP
PHP实现字符串的全排列详解
2019/04/24 PHP
laravel框架 laravel-admin上传图片到oss的方法
2019/10/13 PHP
向fckeditor编辑器插入指定代码的方法
2007/05/25 Javascript
实用框架(iframe)操作代码
2014/10/23 Javascript
Node.js的项目构建工具Grunt的安装与配置教程
2016/05/12 Javascript
JS HTML5拖拽上传图片预览
2016/07/18 Javascript
Bootstrap时间选择器datetimepicker和daterangepicker使用实例解析
2016/09/17 Javascript
vue实现列表的添加点击
2016/12/29 Javascript
vue2.0中goods选购栏滚动算法的实现代码
2017/05/17 Javascript
JavaScript实现二维坐标点排序效果
2017/07/18 Javascript
解决Vue2.0自带浏览器里无法打开的原因(兼容处理)
2017/07/28 Javascript
浅析JavaScript异步代码优化
2019/03/18 Javascript
详解json串反转义(消除反斜杠)
2019/08/12 Javascript
微信小程序实现禁止分享代码实例
2019/10/19 Javascript
vue cli 3.0通用打包配置代码,不分一二级目录
2020/09/02 Javascript
[54:10]完美世界DOTA2联赛PWL S2 Magma vs FTD 第二场 11.29
2020/12/03 DOTA
理解Python垃圾回收机制
2016/02/12 Python
详细介绍Python的鸭子类型
2016/09/12 Python
Python从使用线程到使用async/await的深入讲解
2018/09/16 Python
python实现归并排序算法
2018/11/22 Python
python 划分数据集为训练集和测试集的方法
2018/12/11 Python
Pytorch实现各种2d卷积示例
2019/12/30 Python
解决tensorflow添加ptb库的问题
2020/02/10 Python
一文弄懂Pytorch的DataLoader, DataSet, Sampler之间的关系
2020/07/03 Python
Django执行源生mysql语句实现过程解析
2020/11/12 Python
HTML5之SVG 2D入门3—文本与图像及渲染文本介绍
2013/01/30 HTML / CSS
HTML5拖拽文件上传的示例代码
2021/03/04 HTML / CSS
化石印度尼西亚在线商店:Fossil Indonesia
2019/03/11 全球购物
说出一些常用的类,包,接口
2014/09/22 面试题
经典洗发水广告词
2014/03/13 职场文书
浅谈Redis中的RDB快照
2021/06/29 Redis