python二叉树类及其遍历的实现是怎样的呢
Admin 2022-08-20 群英技术资讯 806 次浏览
这篇文章主要讲解了“python二叉树类及其遍历的实现是怎样的呢”,文中的讲解内容简单、清晰、详细,对大家学习或是工作可能会有一定的帮助,希望大家阅读完这篇文章能有所收获。下面就请大家跟着小编的思路一起来学习一下吧。from collections import deque #层遍历中用到队列数据类型
class BTNode: #二叉链中结点类
def __init__(self,d = None):
self.data = d #结点值
self.lchild = None #左hai子指针
self.rchild = None #右hai子指针
class BTree: #二叉树类
def __init__(self,d = None):
self.b = None #根结点指针
def DispBTree(self): #返回二叉链的括号表示串
return self._DispBTree1(self.b)
def _DispBTree1(self,t): #被DispBTree方法调用
if t==None: #空树返回空串
return ""
else:
bstr = t.data #输出根结点值
if t.lchild != None or t.rchild != None:
bstr += "(" #有hai子结点时输出"("
bstr += self._DispBTree1(t.lchild) #递归输出左子树
if t.rchild != None:
bstr += "," #有右hai子结点时输出","
bstr += self._DispBTree1(t.rchild) #递归输出右子树
bstr += ")" #输出")"
return bstr
def FindNode(self,x): #查找值为x的结点算法
return self._FindNode1(self.b,x)
def _FindNode1(self,t,x): #被FindNode方法调用
if t==None:
return None #t为空时返回null
elif t.data==x:
return t #t所指结点值为x时返回t
else:
p = self._FindNode1(t.lchild,x) #在左子树中查找
if p != None:
return p #在左子树中找到p结点,返回p
else:
return self._FindNode1(t.rchild,x) #返回在右子树中查找结果
def Height(self): #求二叉树高度的算法
return self._Height1(self.b)
def _Height1(self,t): #被Height方法调用
if t==None:
return 0 #空树的高度为0
else:
lh = self._Height1(t.lchild) #求左子树高度lchildh
rh = self._Height1(t.rchild) #求右子树高度rchildh
return max(lh,rh)+1
def PreOrder(bt): #先序遍历的递归算法
_PreOrder(bt.b)
def _PreOrder(t): #被PreOrder方法调用
if t != None:
print(t.data,end = ' ') #访问根结点
_PreOrder(t.lchild) #先序遍历左子树
_PreOrder(t.rchild) #先序遍历右子树
def InOrder(bt): #中序遍历的递归算法
_InOrder(bt.b)
def _InOrder(t): #被InOrder方法调用
if t != None:
_InOrder(t.lchild) #中序遍历左子树
print(t.data,end = ' ') #访问根结点
_InOrder(t.rchild) #中序遍历右子树
def PostOrder(bt): #后序遍历的递归算法
_PostOrder(bt.b)
def _PostOrder(t): #被PostOrder方法调用
if t != None:
_PostOrder(t.lchild) #后序遍历左子树
_PostOrder(t.rchild) #后序遍历右子树
print(t.data,end = ' ') #访问根结点
def LevelOrder(bt): #层序遍历的算法
qu = deque() #将双端队列作为普通队列qu
qu.append(bt.b) #根结点进队
while len(qu)>0: #队不空循环
p = qu.popleft() #出队一个结点
print(p.data,end = ' ') #访问p结点
if p.lchild != None: #有左hai子时将其进队
qu.append(p.lchild)
if p.rchild != None: #有右hai子时将其进队
qu.append(p.rchild)
def CreateBTree2(posts,ins): #由后序序列posts和中序序列ins构造二叉链
bt = BTree()
bt.b = _CreateBTree2(posts,0,ins,0,len(posts))
return bt
def _CreateBTree2(posts,i,ins,j,n):
if n <= 0:
return None
d = posts[i+n-1] #取后序序列尾元素d
t = BTNode(d) #创建根结点(结点值为d)
p = ins.index(d) #在ins中找到根结点的索引
k = p-j #确定左子树中结点个数k
t.lchild = _CreateBTree2(posts,i,ins,j,k) #递归构造左子树
t.rchild = _CreateBTree2(posts,i+k,ins,p+1,n-k-1) #递归构造右子树
return t
if __name__ == '__main__':
inlst = ['D','G','B','A','E','C','F']
posts = ['G','D','B','E','F','C','A']
print(f"中序列表 :{inlst}")
print(f"后序列表 :{posts}")
#构造二叉树bt
bt = BTree()
bt = CreateBTree2(posts,inlst)
print(f"\n构造二叉树:{bt.DispBTree()}")
x = 'F'
if bt.FindNode(x):
print(f"bt中存在 :'{x}'")
else:
print(f"bt中不存在 :'{x}'")
print(f"bt的高度 :{bt.Height():^3}")
print("\n先序遍历 :",end='')
PreOrder(bt)
print("\n中序遍历列 :",end='')
InOrder(bt)
print("\n后序遍历 :",end='')
PostOrder(bt)
print("\n层序遍历 :",end='')
LevelOrder(bt)
中序列表:['D', 'G', 'B', 'A', 'E', 'C', 'F']
后序列表:['G', 'D', 'B', 'E', 'F', 'C', 'A']构造二叉树:A(B(D(,G),C(E,F))
bt中存在 :'F'
bt的高度 : 4先序遍历 :A B D G C E F
中序遍历 :D G B A E C F
后序遍历 :G D B E F C A
层序遍历 :A B C D E F G




免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
今天带大家学习怎么用python实现一个无界面的小型图书管理系统,文中有非常详细的图文解说及代码示例,对正在学习python的小伙伴们有很好地帮助,需要的朋友可以参考下
大家好,本篇文章主要讲的是Pandas按周/月/年统计数据介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
本文给大家分享一个Python基础知识,也就是socket通信原理,一些朋友可能对于socket通信原理不会很理解,因此本文有很详细的介绍,需要的朋友不妨了解看看,那么接下来就跟随小编一起学习一下吧。
程序的编码风格是一个人编写程序时表现出来的特点、习惯逻辑思路等。我们在程序开发时要重视其编写规范,程序不仅应该能够在机器上正确执行,还应便于调试、维护及阅读。下面举例说明一些编程规范。
链表的定义:链表(linkedlist)是由一组被称为结点的数据元素组成的数据结构,每个结点都包含结点本身的信息和指向下一个结点的地址。由于每个结点都包含了可以链接起来的地址信息,所以用一个变量就能够访问整个结点序列。也就是说,结点包含两部分信息:一部分用于存储数据元素的值,称为信息域;另一部分用于存储下一个数据元素地址的指针,称为指针域。链表中的第一个结点的地址存储在一个单独的结点中,称
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008