Python二叉树的遍历操作示例【前序遍历,中序遍历,后序遍历,层序遍历】
作者:DreamLee0625 发布时间:2022-07-06 16:40:59
标签:Python,二叉树,遍历
本文实例讲述了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程序设计有所帮助。
来源:https://blog.csdn.net/vitaminc4/article/details/80964955


猜你喜欢
- 误区 #5: AWE在64位SQL SERVER中必须开启错误! 在坊间流传的有关AWE的设置的各种版本
- 用户登录验证脚本,Chkpwd.asp<% '=======用户登录验证脚本======= '如果尚未定义Passed
- 计时器setTimeout()和setInterval()两个都是js的计时功能的函数两个有些区别。 setTimeout(): 在js手册
- 延迟是什么defer即延迟语句,极个别的情况下,Go才使⽤defer、panic、recover这种异常处理形式。defer可以延迟函数、延
- 一个else语句可以使用if语句结合起来。如果在if语句中的条件表达式解析为0或false值,那么else语句包含代码执行。el
- 怎么增大MySQL数据库连接数,MYSQL数据库安装完成后,默认连接数是100,流量稍微大一点的论坛或网站这个连接数是不够哟用
- 先设定一个关系模型如下:from django.db import modelsclass Blog(models.Model): name
- 看代码吧~name = r"\u6697\u88d4\u5251\u9b54"print(name.encode(
- <select id = "cityList" > <select id =
- 本文实例讲述了JavaScript中filter的用法。分享给大家供大家参考,具体如下:filterfilter也是一个常用的操作,它用于把
- 本文实例讲述了python实现对象列表根据某个属性排序的方法。分享给大家供大家参考,具体如下:对于一个已有的python list, 里面的
- type,元类,类,对象简单描述1.type是python内建元类,新建的元类需要继承type2.元类用来创建类,类用来创建对象类的生成方式
- 使用了两个卷积层加上两个全连接层实现本来打算从头手撕的,但是调试太耗时间了,改天有时间在从头写一份详细过程看代码注释,参考了下一个博主的文章
- 介绍我们可以使用code-generator 以及controller-tools来进行代码自动生成,通过代码自动生成可以帮我们自动生成 C
- 本文实例讲述了python使用Flask框架获取用户IP地址的方法。分享给大家供大家参考。具体如下:下面的代码包含了html页面和pytho
- 介绍在本文中,你将学习如何使用 Python 构建人脸识别系统。人脸识别比人脸检测更进一步。在人脸检测中,我们只检测人脸在图像中的位置,但在
- 本文实例总结了python中日期和时间格式化输出的方法。分享给大家供大家参考。具体分析如下:python格式化日期时间的函数为datetim
- 本文实例讲述了Python高阶函数、常用内置函数用法。分享给大家供大家参考,具体如下:高阶函数:允许将函数作为参数传入另一个函数;允许返回一
- 很常见的一个图片轮播Flash,使用之后发现在IE下按F5刷新之后Flash区域就变成一大块背景色,内容轮播出不来了。有趣的是右键点击Fla
- 在任何编程语言中,检查字符串是否包含子字符串都是常见的任务。例如,假设您正在构建在线游戏。您可能需要检查用户名是否包含禁止使用的短语,以确保