数据结构——二叉树知识点详解!

引言: 本篇博客将详细介绍到数据结构 中的又一位大将------二叉树 。它也是我们目前学到的第一个非线性的数据结构 。并且本章将学到的概念居多,希望大家可以理解并牢记。

更多有关C语言和数据结构知识详解可前往个人主页:计信猫

目录

一,树

1,树的概念

2,树的定义

二,二叉树

1,二叉树的概念

2,特殊的二叉树

[Ⅰ ,满二叉树](#Ⅰ ,满二叉树)

Ⅱ,完全二叉树

3,二叉树的储存

三,结语


一,树

1,树的概念

是一种非线性的数据结构 ,它由n(n>=0)个有限节点组成一个具有层次关系的集合。而在形式上就像一个倒挂的树,根在上,叶在下。如下图,就是一棵树:

想要真正的了解一棵 ,那我们还应该继续掌握关于的细枝末节的概念知识。

父节点/双亲节点 子节点/孩子节点

节点的度: 某节点所含有的子节点 的个数。例如A的度就为2

兄弟节点: 具有相同父节点 的节点。如B,C就为兄弟节点

叶节点/终端节点:子节点 为0的节点。如D,E,F,G,H

堂兄弟节点:父节点处于同一层上的节点。

树的度: 所包含的节点中的 的最大值。例如这棵树的度就为3

树的高度:树 的最大层次(深度)。例如这棵树的高度就为3

森林: 互不相交的的集合。

当然,我们也会遇到两棵比较特殊的,如下:

此时空树高度 就为0,只有根节点的树高度就为1。

想要成为一棵,也需要同时遵守以下规则:

1,子树之间便可以有相连或者相交的情况出现。

2,除了根节点以外,每一个节点有且仅有一个父节点。

2,树的定义

对于 的定义,则存在一个难点,那就是一个节点的子节点的个数不确定性,导致我们不知道该定义多少个指针变量合适。

但是,我们可以使用一个方法,叫做左孩子右兄弟 定义法来完美地解决这个问题。于是我们如下代码定义一个

cpp 复制代码
struct TreeNode
{
    int val;
    struct TreeNode* LeftChild;//左孩子
    struct TreeNode* RightBrother;//右兄弟
};

所以有了这个方法,我们就可以很轻松地将如下的使用代码进行表示了。

而在使用此方法时,我们必须确保左孩子一定是每一层最左边的那一个。于是我们便可以使用如下代码来遍历一棵的某一层。

cpp 复制代码
struct TreeNode*cur=parent->LeftChild;//parent表示根节点
while(cur)
{
    //......
    cur=cur->RightBrother;
}

二,二叉树

1,二叉树的概念

二叉树 无非本质上就首先是一棵 ,所以它拥有 的全部概念。其次二叉树 的特殊之处就是二叉树的度为2 ,也就是说一个节点子节点数 不可以超过2。

那么如下,就是一棵二叉树

2,特殊的二叉树

Ⅰ ,满二叉树

满二叉树 的定义就是除了叶节点 之外,每一个节点都达到含有了两个子节点二叉树。如下图所示:

倘若满二叉树 的高度为H,那么我们便可以计算出它的节点个数:

Ⅱ,完全二叉树

完全二叉树 则要求,前H-1层满二叉树 ,最后一层的叶节点 从左向右连续。如下图所示:

而所要求的**"连续"** 的意思其实就是从左到右必须叶节点 紧挨着叶节点,不可以有空出来的位置。

那我们举出如下反例,便不是完全二叉树:

3,二叉树的储存

对于二叉树 的储存,我们便是将逻辑结构与物理结构进行分离储存。

逻辑结构:树状结构

物理结构:数组结构

利用数组 储存二叉树 数据的好处就是我们可以使用下标找到某个节点的父节点或者子节点

通过下标寻找父/子节点

假设父节点的下标为i: 左孩子节点 的下标为2*i+1右孩子节点 下标为2*i+2

假设子节点的下标为j: 不管j为奇数 或者偶数 ,其父节点 的下标都为**(j-2)/2** ------因为会涉及到int类型取整操作

注意: 若为非完全二叉树 ,则不存在的节点 一定要在数组空出来 ,不然会导致使用下标寻找父子节点的方法失效

三,结语

这一篇文章也仅仅只是讲到了二叉树的概念 而已,接下来我会尽快更新出二叉树数据结构的应用------堆

相较于我们以前学到的数据结构就更加的复杂难懂了,如果想要看懂 ,那么将这篇博客所讲到的知识点,尤其是父子节点下标的寻找 烂熟于心就是非常重要的了**。希望我们可以一起克服我们所遇到的困难,一起加油!**

相关推荐
一直学习永不止步3 分钟前
LeetCode题练习与总结:赎金信--383
java·数据结构·算法·leetcode·字符串·哈希表·计数
wheeldown8 小时前
【数据结构】选择排序
数据结构·算法·排序算法
躺不平的理查德12 小时前
数据结构-链表【chapter1】【c语言版】
c语言·开发语言·数据结构·链表·visual studio
阿洵Rain12 小时前
【C++】哈希
数据结构·c++·算法·list·哈希算法
Leo.yuan12 小时前
39页PDF | 华为数据架构建设交流材料(限免下载)
数据结构·华为
半夜不咋不困13 小时前
单链表OJ题(3):合并两个有序链表、链表分割、链表的回文结构
数据结构·链表
忘梓.13 小时前
排序的秘密(1)——排序简介以及插入排序
数据结构·c++·算法·排序算法
y_m_h16 小时前
leetcode912.排序数组的题解
数据结构·算法
1 9 J16 小时前
数据结构 C/C++(实验三:队列)
c语言·数据结构·c++·算法
921正在学习编程16 小时前
数据结构之二叉树前序,中序,后序习题分析(递归图)
c语言·数据结构·算法·二叉树