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 while 循环使用的简单实例
Jun 08 Python
django admin 后台实现三级联动的示例代码
Jun 22 Python
python 文件查找及内容匹配方法
Oct 25 Python
python训练数据时打乱训练数据与标签的两种方法小结
Nov 08 Python
python+flask实现API的方法
Nov 21 Python
python Tkinter版学生管理系统
Feb 20 Python
python try except返回异常的信息字符串代码实例
Aug 15 Python
django中使用事务及接入支付宝支付功能
Sep 15 Python
开启Django博客的RSS功能的实现方法
Feb 17 Python
python 使用while循环输出*组成的菱形实例
Apr 12 Python
Python Selenium截图功能实现代码
Apr 26 Python
Python调用C/C++的方法解析
Aug 05 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
高分R级DC动画剧《哈莉·奎茵》第二季正式预告首发
2020/04/09 欧美动漫
PHP base64+gzinflate压缩编码和解码代码
2008/10/03 PHP
PHP获取时间排除周六、周日的两个方法
2014/06/30 PHP
浅析Yii2 GridView 日期格式化并实现日期可搜索教程
2016/04/22 PHP
jQuery1.5.1 animate方法源码阅读
2011/04/05 Javascript
把字符串按照特定的字母顺序进行排序的js代码
2014/01/28 Javascript
浅谈JavaScript Date日期和时间对象
2014/12/29 Javascript
ES2015 Symbol 一种绝不重复的值
2016/12/25 Javascript
flexslider.js实现移动端轮播
2017/02/05 Javascript
jquery实现tab选项卡切换效果(悬停、下方横线动画位移)
2017/05/05 jQuery
vue单页开发父子组件传值思路详解
2018/05/18 Javascript
基于React+Redux的SSR实现方法
2018/07/03 Javascript
VUE+Element UI实现简单的表格行内编辑效果的示例的代码
2018/10/31 Javascript
在vue使用clipboard.js进行一键复制文本的实现示例
2019/01/15 Javascript
javascript浅层克隆、深度克隆对比及实例解析
2020/02/09 Javascript
简单介绍Python中的readline()方法的使用
2015/05/24 Python
Python创建模块及模块导入的方法
2015/05/27 Python
Django的数据模型访问多对多键值的方法
2015/07/21 Python
Django admin实现图书管理系统菜鸟级教程完整实例
2017/12/12 Python
Python实现PS图像抽象画风效果的方法
2018/01/23 Python
Python使用爬虫抓取美女图片并保存到本地的方法【测试可用】
2018/08/30 Python
python抓取京东小米8手机配置信息
2018/11/13 Python
Python 确定多项式拟合/回归的阶数实例
2018/12/29 Python
利用Python实现微信找房机器人实例教程
2019/03/10 Python
Pycharm远程调试原理及具体配置详解
2019/08/08 Python
python通过robert、sobel、Laplace算子实现图像边缘提取详解
2019/08/21 Python
Python绘制股票移动均线的实例
2019/08/24 Python
Python中使用gflags实例及原理解析
2019/12/13 Python
pytorch 数据处理:定义自己的数据集合实例
2019/12/31 Python
python中判断文件结束符的具体方法
2020/08/04 Python
世嘉游戏英国官方商店:SEGA Shop UK
2019/09/20 全球购物
一份创业计划书范文
2014/02/08 职场文书
幼儿教师国培感言
2014/02/19 职场文书
员工生日会策划方案
2014/06/14 职场文书
精神文明建设先进个人事迹材料
2014/12/24 职场文书
人工智能深度学习OpenAI baselines的使用方法
2022/05/20 Python