树、二叉树(完全二叉树、满二叉树)概念图解「建议收藏」

树、二叉树(完全二叉树、满二叉树)概念图解「建议收藏」1、树的定义树是n个结点的有限集合,有且仅有一个根结点,其余结点可分为m个根结点的子树。2、树的概念结点的度:一个结点拥有子树的个数称为度。比如A的度为3,C的度为2,H的度为0。度为0的结点称为叶子节点(D,F,G,H)。树的度是树中所有结点的度的最大值,此树的度为3。 树中结点的最大层次成为树的深度或高度。此树的深度为4。 父节点A的子结点B,C,D;B,C,D也是兄弟节点…

大家好,又见面了,我是你们的朋友全栈君。

1、树的定义

树是n个结点的有限集合,有且仅有一个根结点,其余结点可分为m个根结点的子树。

树、二叉树(完全二叉树、满二叉树)概念图解「建议收藏」

2、树的概念

  1. 结点的度:一个结点拥有子树的个数称为度。比如A的度为3,C的度为2,H的度为0。度为0的结点称为叶子节点(D,F,G,H)树的度是树中所有结点的度的最大值,此树的度为3。
  2. 树中结点的最大层次成为树的深度或高度。此树的深度为4。
  3. 父节点A的子结点B,C,D;B,C,D也是兄弟节点
  4. 树的集合称为森林.树和森林之间有着密切的关系.删除一个树的根结点,其所有原来的子树都是树,构成森林.用一个结点连接到森林的所有树的根结点就构成树.

 

3、二叉树 

        二叉树是每个节点最多拥有两个子节点,左子树和右子树是有顺序的不能任意颠倒。

树、二叉树(完全二叉树、满二叉树)概念图解「建议收藏」

 

4、二叉树遍历

前序遍历(前根遍历):——>左——>右

中序遍历(中根遍历):左——>——>右

后序遍历(后根遍历):左——>右——>

已知前序和中序,求后序问题,  前序 ABDGCEFH    中序 DGBAECHF

解法:根据前序、中序综合判断画出树的节点图,然后再写后序遍历:DGBEHFCA

(前序和中序的子树也满足前序或中序的规则)

树、二叉树(完全二叉树、满二叉树)概念图解「建议收藏」

二叉树的深度优先遍历(DFS)与广度优先遍历(BFS)

      DFS深度优先遍历:从根节点出发,沿着左子树方向进行纵向遍历,直到找到叶子节点为止。然后回溯到前一个节点,进行右子树节点的遍历,直到遍历完所有可达节点为止。利用数据结构“栈”,父节点入栈,父节点出栈,先右子节点入栈,后左子节点入栈。递归遍历全部节点。

DFS:ABDGCEFH

 

     BFS广度优先遍历:从根节点出发,在横向遍历二叉树层段节点的基础上纵向遍历二叉树的层次。利用数据结构“队列”,父节点入队,父节点出队列,先左子节点入队,后右子节点入队。递归遍历全部节点。

BFS:ABCDGEFH

 

5、满二叉树 

高度为h,由2^h-1个节点构成的二叉树称为满二叉树。

树、二叉树(完全二叉树、满二叉树)概念图解「建议收藏」

 

6、完全二叉树 

完全二叉树是由满二叉树而引出来的,若设二叉树的深度为h,除第 h 层外,其它各层 (1~h-1) 的结点数都达到最大个数(即1~h-1层为一个满二叉树),第 h 层所有的结点都连续集中在最左边,这就是完全二叉树。

堆一般都是用完全二叉树来实现的。

树、二叉树(完全二叉树、满二叉树)概念图解「建议收藏」

 

未完。。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/158444.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月13日 下午3:36
下一篇 2022年7月13日 下午3:46


相关推荐

  • 概念模型设计「建议收藏」

    4.1.3     概念模型设计概念模型不依赖于具体的计算机系统,他是纯粹反映信息需求的概念结构。建模是在需求分析结果的基础上展开,常常要对数据进行抽象处理。常用的数据抽象方法是‘聚集’和‘概括’。ER方法是设计概念模型时常用的方法。用设计好的ER图再附以相应的说明书可作为阶段成果

    2022年4月6日
    106
  • MATLAB泰勒级数展开

    MATLAB泰勒级数展开相信很多同学 在学习高等数学都经历过泰勒级数展开 感觉特别复杂与麻烦 下面我将给大家介绍一下如何用几行代码实现泰勒展开 例 1 麦克劳林级数前 10 项 symsx gt gt f x sqrt 1 x 2 gt gt taylor f x order 10 ans 35 x 9 128 5 x 7 16 3 x 5 8 x 3 2 x2 关于 x 2 的前 10 项 taylor f x 2 order 10

    2026年3月18日
    1
  • Claude Code 落地实践的工作简易流程

    Claude Code 落地实践的工作简易流程

    2026年3月16日
    3
  • laravel中不使用 remember_token时退出报错,如何解决?

    laravel中不使用 remember_token时退出报错,如何解决?

    2021年10月28日
    60
  • MySql创建视图

    MySql创建视图1 第一类 createviewva fromtable 2 第二类 createviewva name agefromtable 3 第三类 createviewv vid vname vage asselectid name agefromtable 如果涉及到数据量过大 业务逻辑需要跨表查询等等也可建立一个跨表的视图 有三种情况 一 基于同一数据库这种情况较为简单 只需简单的一行 sql 命令 如下

    2026年3月19日
    1
  • MinGW安装过程

    MinGW安装过程一. 下载MinGW官网下载地址:http://sourceforge.net/projects/mingw/二. 安装1. 双击下载好的压缩文件。 2. 然后出现如下界面,点击install(安装)开始安装。 3.指定安装参数选择(安装目录,用户目录选择)后,点击Continue继续下一步。 4.如下界面是下载和设置MinGW的安装配置

    2022年4月9日
    83

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号