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. go导入包

    go导入包 go有很多内置的函数,例如println,不需要引用即可使用.但是如果不借助go的标准库或者第三方库,我们能做的事情有限.在go中,使用关键字import在代码中导入一个包并使用. 修改我 ...

  2. Linux 软硬链接区别

    一.“硬链接“和“软链接“ 链接的概念:链接简单说实际上是一种文件共享的方式,是 POSIX 中的概念,主流文件系统都支持链接文件. 链接的作用:可以将链接简单地理解为 Windows 中常见的快捷方 ...

  3. C++ STL(一)介绍及string

    STL: C++标准模板库的简称,它是C++的一部份.标准C++库的所有的标识符都是在一个名为std的命名空间中定义的 在使用STL中相关模板时,需要包含相关头文件,然后using namespace ...

  4. anaconda里的python版本回退, requirements

    事情起因:我用的python3.7 , 同事机器学习的部分使用tensorflow,只支持python3.6, 所以我从3.7回退到3.6 conda create -n python36 pytho ...

  5. CSS:CSS 图像透明/不透明

    ylbtech-CSS:CSS 图像透明/不透明 1.返回顶部 1. CSS 图像透明/不透明 使用CSS很容易创建透明的图像. 注意:CSS Opacity属性是W3C的CSS3建议的一部分. 更多 ...

  6. ssm+mysql 时间显示相差了12小时的问题 Gson

    怎么改时区,连接字符串加时区都无效,后来才发现原来返回的是对的,并不是时区问题. 后来感觉是gson问题,关键是在其他数据表并没有这个问题. 把 gson改成 Gson gson = new Gson ...

  7. 数据科学工作者(Data Scientist) 的日常工作内容包括什么

    数据科学工作者(Data Scientist) 的日常工作内容包括什么 众所周知,数据科学是这几年才火起来的概念,而应运而生的数据科学家(data scientist)明显缺乏清晰的录取标准和工作内容 ...

  8. docker学习日记一(镜像构建-container commit和image build)

    构建镜像的方式两种: 一.根据已有的container构建-docker container commit 二.根据已有的image构建-docker image build(推荐) containe ...

  9. leetcode.字符串.125验证回文串-Java

    1. 具体题目 给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写.说明:本题中,我们将空字符串定义为有效的回文串. 示例 1: 输入: "A man, a pl ...

  10. zipinfo - 列出关于某个ZIP压缩包的详细信息

    总览 SYNOPSIS zipinfo [-12smlvhMtTz] file[.zip] [file(s) ...] [-x xfile(s) ...] unzip -Z [-12smlvhMtTz ...