python数据结构之二叉树的统计与转换实例

这篇文章主要介绍了python数据结构之二叉树的统计与转换实例,例如统计二叉树的叶子、分支节点,以及二叉树的左右两树互换等,需要的朋友可以参考下

一、获取二叉树的深度



就是二叉树最后的层次,如下图:



实现代码:

代码如下:



def getheight(self):

       
''' 获取二叉树深度 '''

       
return self.__get_tree_height(self.root)



    def
__get_tree_height(self, root):

       
if root is 0:

           
return 0

       
if root.left is 0 and root.right is 0:

           
return 1

       
else:

           
left = self.__get_tree_height(root.left)

           
right = self.__get_tree_height(root.right)

           
if left < right:

               
return right 1

           
else:

               
return left 1



二、叶子的统计



叶子就是二叉树的节点的 left 指针和 right 指针分别指向空的节点

复制代码 代码如下:



def getleafcount(self):

       
''' 获取二叉树叶子数 '''

       
return self.__count_leaf_node(self.root)



    def
__count_leaf_node(self, root):

       
res = 0

       
if root is 0:

           
return res

       
if root.left is 0 and root.right is 0:

           
res = 1

           
return res

       
if root.left is not 0:

           
res = self.__count_leaf_node(root.left)

       
if root.right is not 0:

           
res = self.__count_leaf_node(root.right)

       
return res



三、统计叶子的分支节点



与叶子节点相对的其他节点 left 和 right 的指针指向其他节点



复制代码 代码如下:



def getbranchcount(self):

       
''' 获取二叉树分支节点数 '''

       
return self.__get_branch_node(self.root)



    def
__get_branch_node(self, root):

       
if root is 0:

           
return 0

       
if root.left is 0 and root.right is 0:

           
return 0

       
else:

           
return 1 self.__get_branch_node(root.left)
self.__get_branch_node(root.right)



四、二叉树左右树互换



代码如下:



def replacelem(self):

       
''' 二叉树所有结点的左右子树相互交换 '''

       
self.__replace_element(self.root)



    def
__replace_element(self, root):

       
if root is 0:

           
return

       
root.left, root.right = root.right, root.left

       
self.__replace_element(root.left)

       
self.__replace_element(root.right)

这些方法和操作,都是运用递归。其实二叉树的定义也是一种递归。附上最后的完整代码:

代码如下:



# -*- coding: utf - 8 - *-



    

class TreeNode(object):



    def
__init__(self, left=0, right=0, data=0):

       
self.left = left

       
self.right = right

       
self.data = data



    

class BinaryTree(object):



    def
__init__(self, root=0):

       
self.root = root



    def
is_empty(self):

       
if self.root is 0:

           
return True

       
else:

           
return False



    def
create(self):

       
temp = input('enter a value:')

       
if temp is '#':

           
return 0

       
treenode = TreeNode(data=temp)

       
if self.root is 0:

           
self.root = treenode



       
treenode.left = self.create()

       
treenode.right = self.create()



    def
preorder(self, treenode):

       
'前序(pre-order,NLR)遍历'

       
if treenode is 0:

           
return

       
print treenode.data

       
self.preorder(treenode.left)

       
self.preorder(treenode.right)



    def
inorder(self, treenode):

       
'中序(in-order,LNR'

       
if treenode is 0:

           
return

       
self.inorder(treenode.left)

       
print treenode.data

       
self.inorder(treenode.right)



    def
postorder(self, treenode):

       
'后序(post-order,LRN)遍历'

       
if treenode is 0:

           
return

       
self.postorder(treenode.left)

       
self.postorder(treenode.right)

       
print treenode.data



    def
preorders(self, treenode):

       
'前序(pre-order,NLR)非递归遍历'

       
stack = []

       
while treenode or stack:

           
if treenode is not 0:

               
print treenode.data

               
stack.append(treenode)

               
treenode = treenode.left

           
else:

               
treenode = stack.pop()

               
treenode = treenode.right



    def
inorders(self, treenode):

       
'中序(in-order,LNR) 非递归遍历'

       
stack = []

       
while treenode or stack:

           
if treenode:

               
stack.append(treenode)

               
treenode = treenode.left

           
else:

               
treenode = stack.pop()

               
print treenode.data

               
treenode = treenode.right



    def
postorders(self, treenode):

       
'后序(post-order,LRN)非递归遍历'

       
stack = []

       
pre = 0

       
while treenode or stack:

           
if treenode:

               
stack.append(treenode)

               
treenode = treenode.left

           
elif stack[-1].right != pre:

               
treenode = stack[-1].right

               
pre = 0

           
else:

               
pre = stack.pop()

               
print pre.data



    # def
postorders(self, treenode):

   
#    
'后序(post-order,LRN)非递归遍历'

   
#    
stack = []

   
#    
queue = []

   
#    
queue.append(treenode)

   
#    
while queue:

   
#        
treenode = queue.pop()

   
#        
if treenode.left:

   
#            
queue.append(treenode.left)

   
#        
if treenode.right:

   
#            
queue.append(treenode.right)

   
#        
stack.append(treenode)

   
#    
while stack:

   
#        
print stack.pop().data



    def
levelorders(self, treenode):

       
'层序(post-order,LRN)非递归遍历'

       
from collections import deque

       
if not treenode:

           
return

       
q = deque([treenode])

       
while q:

           
treenode = q.popleft()

           
print treenode.data

           
if treenode.left:

               
q.append(treenode.left)

           
if treenode.right:

               
q.append(treenode.right)



    def
getheight(self):

       
''' 获取二叉树深度 '''

       
return self.__get_tree_height(self.root)



    def
__get_tree_height(self, root):

       
if root is 0:

           
return 0

       
if root.left is 0 and root.right is 0:

           
return 1

       
else:

           
left = self.__get_tree_height(root.left)

           
right = self.__get_tree_height(root.right)

           
if left < right:

               
return right 1

           
else:

               
return left 1



    def
getleafcount(self):

       
''' 获取二叉树叶子数 '''

       
return self.__count_leaf_node(self.root)



    def
__count_leaf_node(self, root):

       
res = 0

       
if root is 0:

           
return res

       
if root.left is 0 and root.right is 0:

           
res = 1

           
return res

       
if root.left is not 0:

           
res = self.__count_leaf_node(root.left)

       
if root.right is not 0:

           
res = self.__count_leaf_node(root.right)

       
return res



    def
getbranchcount(self):

       
''' 获取二叉树分支节点数 '''

       
return self.__get_branch_node(self.root)



    def
__get_branch_node(self, root):

       
if root is 0:

           
return 0

       
if root.left is 0 and root.right is 0:

           
return 0

       
else:

           
return 1 self.__get_branch_node(root.left)
self.__get_branch_node(root.right)



    def
replacelem(self):

       
''' 二叉树所有结点的左右子树相互交换 '''

       
self.__replace_element(self.root)



    def
__replace_element(self, root):

       
if root is 0:

           
return

       
root.left, root.right = root.right, root.left

       
self.__replace_element(root.left)

       
self.__replace_element(root.right)



node1 = TreeNode(data=1)

node2 = TreeNode(node1, 0, 2)

node3 = TreeNode(data=3)

node4 = TreeNode(data=4)

node5 = TreeNode(node3, node4, 5)

node6 = TreeNode(node2, node5, 6)

node7 = TreeNode(node6, 0, 7)

node8 = TreeNode(data=8)

root = TreeNode(node7, node8, 'root')



    

bt = BinaryTree(root)



print u'''



生成的二叉树



------------------------

        
root

     
7       
8

    6

  2   5

1    3 4



-------------------------



'''

python数据结构之二叉树的统计与转换实例的更多相关文章

  1. python数据结构之二叉树的实现

    树的定义 树是一种重要的非线性数据结构,直观地看,它是数据元素(在树中称为结点)按分支关系组织起来的结构,很象自然界中的树那样.树结构在客观世界中广泛存在,如人类社会的族谱和各种社会组织机构都可用树形 ...

  2. Python数据结构之二叉树

    本来打算一个学期分别用C++.Python.Java实现数据结构,看来要提前了 这个是Python版本,我写的数据结构尽量保持灵活性,本文bt1是一般的插入法建立二叉树结构,bt2就是可以任意输入,至 ...

  3. python数据结构之二叉树遍历的实现

    本篇是实现二叉树的三种遍历,先序遍历,中序遍历,后序遍历 #!/usr/bin/python # -*- coding: utf-8 -*- class TreeNode(object): def _ ...

  4. python 数据结构之二叉树

    二叉树关键在构建和遍历,python实现相对简单,我们在实现需要用到类,分别设置爱左右子树,根节点,然后从根进行遍历,进行判断,若为空进行树的构建,非空则返回到列表中即可,我在进行遍历时产生了一个错误 ...

  5. python数据结构之二叉树的遍历实例

    遍历方案   从二叉树的递归定义可知,一棵非空的二叉树由根结点及左.右子树这三个基本部分组成.因此,在任一给定结点上,可以按某种次序执行三个操作:   1).访问结点本身(N)   2).遍历该结点的 ...

  6. python数据结构之二叉树的建立实例

    先建立二叉树节点,有一个data数据域,left,right 两个指针域 # coding:utf-8 class TreeNode(object): def __init__(self,left=N ...

  7. python数据结构树和二叉树简介

    一.树的定义 树形结构是一类重要的非线性结构.树形结构是结点之间有分支,并具有层次关系的结构.它非常类似于自然界中的树.树的递归定义:树(Tree)是n(n≥0)个结点的有限集T,T为空时称为空树,否 ...

  8. Python实现打印二叉树某一层的所有节点

    不多说,直接贴程序,如下所示 # -*- coding: utf-8 -*- # 定义二叉树节点类 class TreeNode(object): def __init__(self,data=0,l ...

  9. python数据结构之图的实现方法

    python数据结构之图的实现方法 本文实例讲述了python数据结构之图的实现方法.分享给大家供大家参考.具体如下: 下面简要的介绍下: 比如有这么一张图:     A -> B     A ...

随机推荐

  1. PHP FILTER_VALIDATE_EMAIL 过滤器

    定义和用法 FILTER_VALIDATE_EMAIL 过滤器把值作为 e-mail 地址来验证. Name: "validate_email" ID-number: 274 实例 ...

  2. STM32嵌入式开发学习笔记(一)

    本文中,笔者将介绍使用嵌入式开发工具Keil uVision5,使用C语言,对微处理器STM32F103C8进行嵌入式开发. 开发使用C语言,首先需要新建一个C语言文件,将其设为主函数的入口,因此,将 ...

  3. CSS:CSS 分组 和 嵌套 选择器

    ylbtech-CSS:CSS 分组 和 嵌套 选择器 1.返回顶部 1. CSS 分组 和 嵌套 选择器 Grouping Selectors 在样式表中有很多具有相同样式的元素. h1 { col ...

  4. 1. USB协议

    1.1 Packets USB总线上数据传输以包为基本单位,一个包含不同的域,但都要从同步域开始,然后跟踪一个包标识符PID(Packet Identifier),最终以包结束符EOP(End of ...

  5. 文本表征:SoW、BoW、TF-IDF、Hash Trick、doc2vec、DBoW、DM

    原文地址:https://www.jianshu.com/p/2f2d5d5e03f8 一.文本特征 (一)基本文本特征提取 词语数量 常,负面情绪评论含有的词语数量比正面情绪评论更多. 字符数量 常 ...

  6. Codeforcs 1183B Equalize Prices

    题目链接:codeforces.com/problemset/problem/1183/B 题意:给你 n 个数,每个数能在k范围内上下浮动,求能否使所有数相等,能输出相等的最大值,不能输出 -1. ...

  7. C#基础-->cookie和session

    关于cookie和session cookie 1:一个cookie中可以存放的数据最大在4KB左右 2:cookie存放于客户端 3:cookie分为两种  一种是会话cookie  一种是持久co ...

  8. 问题:Error running 'lugia-web': Address loaclhost:1099 is already in use

    解决方法:cmd输入下面命令: 第一步: netstat -ano|findstr 1099 找到对应的pid 为3576.(每次不一样). 第二步:taskkill -f -pid 3576

  9. 详解Telecom

    学习目标: 掌握Telecom入口和分析方法 总结和演进Telecom交互模型 掌握Listener消息回调机制 学习CallsManager 为什么选择Telecom分析? 这是由于在Android ...

  10. 调用phone库,查询手机号码归属地(4)

    需要安装pymysql,phone库 #!/usr/bin/python # -*- coding: utf-8 -*- import sys, pymysql, logging, phone fro ...