- 1、本文档共11页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
课时2二叉树的基本操作
课时目标
1.掌握使用数组和链表等数据结构建立二叉树的方法。2.掌握二叉树遍历的基本操作方法。
1.建立二叉树的方法
建立二叉树的操作方法为:按照二叉树层的顺序进行,先由第________层开始,依次到下一层,在每一层中按照从__________的顺序创建节点。
2.用数组实现二叉树的创建
(1)完全二叉树
①从二叉树的__________开始,按__________、自左向右的顺序对n个节点进行编号,根节点的编号为0,最后一个节点的编号为________。
②然后依次将二叉树的节点用一组连续的数组元素来表示,节点编号与__________一一对应。
(2)非完全二叉树
①对于非完全二叉树,先将它补全为一棵________二叉树,补上的节点及分支用虚线表示。
②然后按照完全二叉树的方法,将节点存储在数组中。
(3)使用数组(列表)建立二叉树
空树用None表示,非空二叉树用包含三个元素的列表[d,l,r]表示,分别存储着根节点的元素和左右子树,因此二叉树的list实现采用嵌套括号([])的形式。
用数组(列表)构建二叉树的代码如下:
defcreate_tree(tree,data):
foriinrange(len(data)):
depth=0#程序的第0层相当于树的第1层
ifi==0:#根节点
tree[depth]=data[i]
else:
#while循环结束表示找到存放数据的节点(索引)位置
whiletree[depth]!=0:
ifdata[i]tree[depth]:#往右寻找
depth=depth*2+2#父节点的右孩子位置
else:#往左寻找
depth=depth*2+1#父节点的左孩子位置
tree[depth]=data[i]#找到数据应存放的节点位置,并存储该节点
3.用链表实现二叉树的创建
二叉树用链表实现时,二叉树的节点至少需要三个域:一个__________和两个__________。如下图所示:
Lchild
data
rchild
其中lchild和rchild是指针域,存放指向节点的左孩子节点和右孩子节点的指针,data是数据域。
使用链表建立有哪些信誉好的足球投注网站二叉树如下:
definsert(self,data):
ifself.data:#如果根节点不存在
ifdataself.data:#插入值小于当前节点值
ifself.left:
self.left.insert(data)#递归调用往下一层
else:
self.left=Node(data)#建立新节点存放数据
else:#插入值大于当前节点值
ifself.right:
self.right.insert(data)
else:
self.right=Node(data)
else:#如果根节点不存在
self.data=data#建立根节点
4.二叉树的遍历
(1)二叉树的遍历是指按照一定的____________访问二叉树中的所有节点,使得每个节点都被访问一次且________________。
(2)根据访问根节点的先后顺序可以分为:前序遍历、____________和____________。
①前序遍历
前序遍历,也称为先序遍历,前序遍历的规则为:若二叉树为空,则空操作返回;否则,先访问________,再访问________,最后访问________。
②中序遍历
中序遍历的规则为:若二叉树为空,则空操作返回;否则,先访问________,再访问根节点,最后访问________。
③后序遍历
后序遍历的规则为:若二叉树为空,则空操作返回;否则,先访问左子树,再访问右子树,最后访问________。
二叉树的三种遍历是根据访问根节点的先后次序来命名的,前序遍历的访问顺序为根左右(BLR),中序遍历的访问顺序为左根右(LBR),后序遍历的访问顺序为左右根(LRB)。
例1下列二叉树中,中序遍历结果为BAEDFC的是()
听课笔记:
变式训练某二叉树前序遍历为ABDFGCEH,后序遍历为FGDBHECA,则下列选项不可能是此二叉树的是()
例2某二叉树的树形结构
您可能关注的文档
- 高中信息技术浙教版(2019)选修1 第六章 课时2 POI数据的组织与应用 课件.pptx
- 高中信息技术浙教版(2019)选修1 第三章 课时1 字符串 课件.pptx
- 高中信息技术浙教版(2019)选修1 第三章 课时2 队列 课件.pptx
- 高中信息技术浙教版(2019)选修1 第三章 课时3 栈 课件.pptx
- 高中信息技术浙教版(2019)选修1 第四章 课时1 树与二叉树 课件.pptx
- 高中信息技术浙教版(2019)选修1 第四章 课时2 二叉树的基本操作 课件.pptx
- 高中信息技术浙教版(2019)选修1 第四章 课时3 抽象数据类型 课件.pptx
- 高中信息技术浙教版(2019)选修1 第四章 验收卷(三) 树 课件.pptx
- 高中信息技术浙教版(2019)选修1 第五章 课时1 数据结构与算法关系 课件.pptx
- 高中信息技术浙教版(2019)选修1 第五章 课时2 迭代与递归 课件.pptx
- 第九章 销售与收款循环审计 .pdf
- 1.9《体积单位间的进率》说课(课件)-2024-2025学年六年级上册数学苏教版.pptx
- 长方体和正方体的体积计算(课件)-2023-2024学年人教版五年级数学下册.pptx
- 第二次月考素养提升卷(5~6单元)(试题)-2024-2025学年五年级数学上册人教版.docx
- 4.表内乘法(一)(乘加、乘减)(课件)-2024-2025学年二年级上册数学人教版.pptx
- 表内乘法(7的乘法口诀)(课件)-2024-2025学年二年级上册数学人教版.pptx
- 吨的认识(课件)-2024-2025学年三年级上册数学人教版.pptx
- 期中检测卷(试题)-2024-2025学年五年级上册语文统编版.docx
- 第七单元《扇形统计图》思维拓展练习(课件)-2024-2025学年六年级上册数学人教版.pptx
- 本文中来自ASME BPE标准委员会的现任委员将一一为您答疑解惑 .pdf
文档评论(0)