二叉树和堆

韩瑛
• 阅读 691
声明:图片引用自《极客时间——数据结构与算法之美》

二叉树

二叉树:就是最多只能有两个叉的树结构。
二叉树和堆
图中1是普通的二叉树,2、3是两种特殊的二叉树。
2是满二叉树
满二叉树:叶子节点全都在最底层,除了叶子节点之外,每个节点都有左右两个子节点

3是完全二叉树
完全二叉树:叶子节点都在最底下两层,最后一层的叶子节点都靠左排列,并且除了最后一层,其他层的节点个数都要达到最大
二叉树和堆
不是完全二叉树的例子中:
第1个,不满足叶子节点都在最底下两层
第2个,不满足最后一层的叶子节点都靠左排列
第3个,不满足除了最后一层外,其他层的节点个数要达到最大

二叉树的具体存储表示

链式存储法
二叉树和堆

每个节点有三个部分,data存储数据,left、right部分是指针,存储节点的指向。类似链表。

代码中,可以想到用对象构建。

顺序存储法
二叉树和堆

顺序存储法,就是基于数组的存储方式。不需要像链式存储那样,每个节点还要保存left、right指针,占用额外的空间,顺序存储法只浪费一个下标0的存储空间。

当前,前提是这棵树是完全二叉树,所以完全二叉树是最适合用顺序存储法的树结构,这也是为什么完全二叉树要求最后一层子节点都靠左排列的原因。

如果节点 X 存储在数组中下标为 i 的位置,下标为 2 * i 的位置存储的就是左子节点,下标为 2 * i + 1 的位置存储的就是右子节点。反过来,下标为 i/2 的位置存储就是它的父节点。

二叉树的遍历

二叉树的三种遍历方式:

  • 前序遍历
    对于树中的任意节点来说,先打印这个节点,然后再打印它的左子树,最后打印它的右子树。
  • 中序遍历
    对于树中的任意节点来说,先打印它的左子树,然后再打印它本身,最后打印它的右子树。
  • 后序遍历
    对于树中的任意节点来说,先打印它的左子树,然后再打印它的右子树,最后打印这个节点本身。

简单总结:
节点自身什么时候打印,就是那种遍历。
节点自身最先打印,就是前序遍历;
节点自身中间的时候打印,就是中序遍历;
节点自身最后一个打印,就是后续遍历。

二叉树的遍历过程就是一个递归,只是递归的顺序不同,有了三种不同的遍历方式。

二叉树和堆

遍历二叉树的时间复杂度:
不管是哪种遍历方式,节点最多会被访问两次,所以总的遍历时间只和节点个数n有关,所以时间复杂度是O(n)

堆结构是二叉树结构的一种,它必须满足以下要求:

  • 堆是一个完全二叉树
  • 每个节点的值必须都大于等于(或小于等于)其左右子节点的值

节点的值大于等于左右子节点的值,这种堆叫做大顶堆,因为它的根节点的值是最大的。

节点的值小于等于左右子节点的值,这种堆叫做小顶堆,因为它的根节点的值是最小的。

二叉树和堆

1、2是大顶堆,3是小顶堆,4不是堆,因为它不是完全二叉树。

点赞
收藏
评论区
推荐文章
白茶清欢 白茶清欢
4年前
js实现二叉树、二叉查找树
树是一种数据结构,该章节讨论二叉树(二叉树的每个节点的子节点不允许超过两个),二叉树中有又分为完全二叉树和不完全二叉树.....不在本章节赘述相关概念,感兴趣可以去查阅《数据结构》。你将会获得:1.如何使用js实现二叉查找树。2.学会前、中、后序遍历。3.了解相关实现原理阅读时长5min,可选择直接调试代码特点    二叉查找树中序遍历后
似梦清欢 似梦清欢
3年前
树与二叉树
二叉树层次建树二叉树(BinaryTree)是由有限个结点组成的集合,它或者为空集合,或者仅含一个根结点,或者由一个根结点和两棵互不相交的左、右子树组成。树为空即根节点为空。二叉树的基本形态如下图:a:空的二叉树,treeNULL。b:只有空节点的二叉树,
22 22
4年前
二叉树创建后,如何使用递归和栈遍历二叉树?
0.前言前文主要介绍了树的相关概念和原理,本文主要内容为二叉树的创建及遍历的代码实现,其中包括递归遍历和栈遍历。1.二叉树的实现思路1.0.顺序存储——数组实现前面介绍了满二叉树和完全二叉树,我们对其进行了编号——从0到n的不中断顺序编号,而恰好,数组也有一个这样的编号——数组下标,只要我们把二者联合起来,数组就能存储二叉树了。那么非满
小恐龙 小恐龙
4年前
彻底搞懂系列B-树、B+树、B-树、B*树
(https://blog.csdn.net/chai471793/article/details/99563704)平衡二叉树概念平衡二叉树是基于二分法的策略提高数据的查找速度的二叉树的数据结构;特点平衡二叉树是采用二分法思维把数据按规则组装成一个树形结构的数据,用这个树形结构的数据减少无关数据的检索,大大
Wesley13 Wesley13
4年前
Java实现 LeetCode 814 二叉树剪枝 (遍历树)
814\.二叉树剪枝给定二叉树根结点root,此外树的每个结点的值要么是0,要么是1。返回移除了所有不包含1的子树的原二叉树。(节点X的子树为X本身,以及所有X的后代。)示例1:输入:\1,null,0,0,1\输出:\1,null,0,null,1\解释:
Wesley13 Wesley13
4年前
PHP数据结构与算法:二叉树
一、定义二叉树是每个节点最多有两个子树的树结构。通常子树被称作“左子树”(leftsubtree)和“右子树”(rightsubtree)。二、特性1.在二叉树的第i层上至多有2^(i1)个结点(i0)2.深度为k的二叉树至多有2^k1个结点(k0)3.对于任意一棵二叉树,如果其叶结点数为N0,而
Stella981 Stella981
4年前
LeetCode(110):平衡二叉树
Easy!题目描述:给定一个二叉树,判断它是否是高度平衡的二叉树。本题中,一棵高度平衡二叉树定义为:一个二叉树_每个节点_的左右两个子树的高度差的绝对值不超过1。示例1:给定二叉树 3,9,20,null,null,15,73/\920/
Wesley13 Wesley13
4年前
Mysql表设计需要注意的问题
下面探讨的数据库为MySQL存储引擎为innodb因为这是最常见的,使用最多的数据库和引擎什么是页分裂?这是因为聚簇索引采用的是平衡二叉树算法,而且每个节点都保存了该主键所对应行的数据,假设插入数据的主键是自增长的,那么根据二叉树算法会很快的把该数据添加到某个节点下,而其他的节点不用动;但是如果插入的是不规则的数据,那么每次插入都会改变二叉树之前
Stella981 Stella981
4年前
Leetcode Lect4 二叉树中的分治法与遍历法
在这一章节的学习中,我们将要学习一个数据结构——二叉树(BinaryTree),和基于二叉树上的搜索算法。在二叉树的搜索中,我们主要使用了分治法(DivideConquer)来解决大部分的问题。之所以大部分二叉树的问题可以使用分治法,是因为二叉树这种数据结构,是一个天然就帮你做好了分治法中“分”这个步骤的结构。本章节的先修内容有:
菜园前端 菜园前端
2年前
什么是二叉树?
原文链接:什么是二叉树?树中每个节点最多只能有两个子节点,在JavaScript中一般都是通过Object来模拟二叉树。常用操作前序遍历中序遍历后序遍历前序遍历根左右。口诀:1.访问根节点2.对根节点的左子树进行前序遍历3.对根节点的右子树进行前序遍历通过
贾蔷 贾蔷
8个月前
手搓二叉树构建类代码详解:从入门到实践(适合新手小白)
一、简介和应用二叉树是数据结构中常见的一种树形结构,每个节点最多有两个子节点(左子节点和右子节点)。它广泛应用于算法设计、数据存储与搜索(如二叉搜索树)、表达式解析等领域。本文将通过手写的C代码,讲解如何构建一个基础的二叉树类,帮助新手理解其原理与实现