0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

二叉树,一种基础的数据结构类型

8g3K_AI_Thinker 来源:lp 2019-04-13 10:48 次阅读

作为数据结构的基础,树分很多种,像AVL树、红黑树、二叉搜索树....今天我想分享的是关于二叉树,一种基础的数据结构类型。

01

什么是树

在《数据结构》[注1]中树有如下定义:

树是 n(n≥0) 个结点的有限集

在此我对上述定义做出如下解释:

当n=0n=0时,为空树,树的深度与高度均为00,是树的一种特例;当n>0n>0时,为非空树,树的第一个结点,即深度为11的结点,我们称其为根结点,由根结点可以引出若干子树分支,同时子树分支可依此向下延伸,此时树的深度与高度也在变化,即树状图。

这里我们需要厘清树的深度与树的高度与其他树的术语:

树的深度:树中结点的最大层次

树的高度:从叶子结点开始定义,叶子结点为第一层,往上依次递增,直至根结点。

结点:树的结点包含一个数据元素以及若干指向其子树的分支

度:结点所拥有的子树数量

终端节点:度为0的结点称为叶子结点或终端结点

树的度:树中各结点度的最大值

层次:从根开始定义,根为第一层,依次递增

有序树:树中结点的各子树从左往右是有次序的,不可相互交换;反之则是无序树

森林:一棵非空树删掉根结点,即是森林

02

二叉树的概念引入

二叉树是由树演化而来的一种数据结构,上面所有术语均适用于二叉树。二叉树与树不同之处在于,树的每一个结点(除终端结点外)允许有若干子树分支;而二叉树只允许有左右两个子树分支,即不存在度大于2结点。

C语言示例:

上面的示例清晰地阐明了二叉树的结点是由一个数据元素和两个子树分支构成,需要明确的是,虽然终端结点没有指向任何子树,但它仍旧有往下繁衍的能力。

除此之外,二叉树还是一棵有序树,它的各个结点从左到右是依次有序可循的,且不可交换;它具有以下五种形态:

空树

仅有根结点

左子树为空

右子树为空

左右子树均非空

当二叉树处于第五种状态,且设树的深度为n,总结点数为 时,我们称其为满二叉树。

‍‍事实上还有另外一种也处于第五状态的树——完全二叉树。由于完全二叉树的定义在每个版本的教科书中均不相同,而笔者只接触过《数据结构·严蔚敏版》,因此摘录此书中对完全二叉树的定义:

深度为k的,有n个结点的二叉树,当且仅当其每一个结点都与深度为k的满二叉树中编号从1至n的结点一一对应时,称之为完全二叉树。

这段描述我读了两遍,方才理解其中的深刻含义,我们把深度为3的满二叉树的每个结点从上往下,从左往右进行编号:‍‍

然后我们再定义一棵深度也为3的二叉树,该二叉树的n 个结点(n≤7),当从1到n的每个结点都与上图中的编号结点一一对应时,这二叉树就称为完全二叉树。

举个例子,当n=5时:

这便是完全二叉树。

因此我们还可以得到一个推论:满二叉树是完全二叉树,但完全二叉树不一定是满二叉树。

当二叉树处于第三种状态时,称其为右斜树。

同理,处于第四状态为左斜树。

‍‍‍‍03

二叉树的性质总结

二叉树的第i 层上最多有个结点。此性质可通过上面满二叉树的图示推得

深度为n 的二叉树,最多拥有 个结点。此性质可以通过数列求和得出:

设满二叉树深度为 n,叶子结点数必为

设任意一棵二叉树的叶子结点数为n0,度为1的结点数为n1,度为2的结点数为n2;总结点数为n。则有:

设分支的总边数为x,则有:

联立上述三式可得:

即任意二叉树的叶子结点数为该树中度为2的结点数的总和加一。

设一完全二叉树具有n个结点,则其深度必为,[x] 表示不大于 x 的最大整数,即向下取整。

04

手把手建立二叉树

C语言示例:

其中需要指明的是二叉树的三种遍历方法:先序遍历、中序遍历、后序遍历。

先序遍历

即遍历顺序为“根—>左->右”。

中序遍历

即遍历顺序为“左—>根—>右”,由于二叉树为有序树,因此中序遍历输出的值由小到大的。

后序遍历

即遍历顺序为“左—>右—>根”。

还有一种遍历法,称为层序遍历,有兴趣的读者可以尝试着写一下。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 数据结构
    +关注

    关注

    3

    文章

    564

    浏览量

    39899
  • 二叉树
    +关注

    关注

    0

    文章

    74

    浏览量

    12238

原文标题:二叉树的原理推敲与动手种树

文章出处:【微信号:AI_Thinker,微信公众号:人工智能头条】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    二叉树二叉树的性质(1)#数据结构

    数据函数二叉树
    未来加油dz
    发布于 :2023年09月05日 09:06:44

    二叉树二叉树的性质(2)#数据结构

    数据函数二叉树
    未来加油dz
    发布于 :2023年09月05日 09:08:32

    二叉树二叉树的性质(3)#数据结构

    数据函数二叉树
    未来加油dz
    发布于 :2023年09月05日 09:09:51

    平衡二叉树(1)#数据结构

    数据函数二叉树
    未来加油dz
    发布于 :2023年09月05日 09:42:30

    平衡二叉树(2)#数据结构

    数据函数二叉树
    未来加油dz
    发布于 :2023年09月05日 09:43:54

    平衡二叉树(3)#数据结构

    数据函数二叉树
    未来加油dz
    发布于 :2023年09月05日 09:45:06

    计算机二叉树的问题

    各位大神,本人马上要考计算机级了,那个二叉树老是弄不明白,比如个题目,二叉树共有25个节点,其中五个叶子节点,则度为1的节点数为?
    发表于 09-04 09:45

    二叉树删除算法

    二叉树的删除操作主要是寻找替代点来进行替换操作。方法:先右转,再直左转,直到左连接为空的那个点。然后,摘取出来,完成链接指向操作。public void deletmin(void){ root
    发表于 12-30 20:55

    二叉查找(GIF动图讲解)

    ,则右子树上所有结点的值均大于它的根结点的值;·任意节点的左、右子树也分别为二叉查找;·没有键值相等的节点。二叉查找相比于其他数据结构
    发表于 07-29 15:24

    收藏 | 程序员面试,你必须知道的8大数据结构

    面试题会明确提及某种数据结构,例如,“给定二叉树。”而另些则隐含在面试题中,例如,“我们希望记录每个作者相关的书籍数量。”即便是对于
    发表于 09-30 09:35

    什么是“红黑”看了就知道

    今天我们要说的红黑就是就是棵非严格均衡的二叉树,均衡二叉树又是在二叉搜索的基础上增加了自动
    发表于 10-27 17:00

    Java编程求二叉树的镜像两种方法介绍

    给出二叉树,求它的镜像,如下图:右边是二叉树是左边二叉树的镜像。仔细分析这两棵的特点,看看能不能总结出求镜像的步骤。这两棵
    发表于 12-16 16:25

    MySQL数据库索引的底层是怎么实现的

    二叉树,B,B+这4种数据结构,以及为啥选用B+作为mysql数据库的
    发表于 07-28 15:30

    详解电源二叉树到底是什么

    作为数据结构的基础,树分很多种,像 AVL 树、红黑树、二叉搜索树....今天我想分享的是关于二叉树一种基础的数据结构
    的头像 发表于 06-06 15:05 9322次阅读
    详解电源<b class='flag-5'>二叉树</b>到底是什么

    C语言数据结构:什么是二叉树

    完全二叉树:完全二叉树是效率很高的数据结构。对于深度为K,有n个节点的二叉树,当且仅当每一个节点都与深度为K的满二叉树中编号从1至n的节点一
    的头像 发表于 04-21 16:20 1683次阅读