Bootstrap

【数据结构】二叉树初阶全解析(第一章)

前言🎆

笔者也仅是大一萌新,写博客为了记录和巩固知识✨

赠人玫瑰,手留余香,欢迎各位读者进行交流和建议🥰

能与大家一起学习,一起进步是我的荣幸🌹

如果这篇文章有帮助到您,还请留个赞支持一下哦🤞



preview

目录🎆

Ⅰ.树的介绍

  1. 树的概念
  2. 树与非树
  3. 树的名称
  4. 树的表示
  5. 什么是二叉树

Ⅱ.二叉树的介绍

  1. 二叉树的组成
  2. 普通二叉树
  3. 特殊二叉树
  4. 二叉树的性质
  5. 二叉树性质题目
  6. 二叉树的存储结构

Ⅰ.树的介绍✨

1.树的概念🎄

树是一种非线性的数据结构,它是由n(n>=0)个有限结点组成一个具有层次关系的集合。

  • 根结点是一个特殊的结点,它没有前驱结点
  • 除根结点外,其余结点被分为M(M>0)个互不相交集合,其中每一个集合又是一棵结构与树类似的子树。每棵子树的根结点有且只有一个前驱,可以有0个或多个后继
  • 树是递归定义的。image-20220411203044861
2.树与非树🎄

以下三种均不是树,树是不具有回路的(这种带环的结构是"图")

image-20220411213007328

树的结构:

image-20220411203435581

3.树的名称🎄

image-20220412155754243

节点的度:一个节点含有的子树的个数称为该节点的度; 如上图:E的为3
叶节点或终端节点度为0的节点称为叶节点; 如上图:B、C、H、I…等节点为叶节点
非终端节点或分支节点度不为0的节点; 如上图:D、E、F、G…等节点为分支节点
双亲节点或父节点:若一个节点含有子节点,则这个节点称为其子节点的父节点; 如上图:A是B的父节点
孩子节点或子节点:一个节点含有的子树的根节点称为该节点的子节点; 如上图:B是A的孩子节点
兄弟节点:具有相同父节点的节点互称为兄弟节点; 如上图:B、C是兄弟节点
树的度:一棵树中,最大的节点的度称为树的度; 如上图:树的度为6
节点的层次:从根开始定义起,根为第1层,根的子节点为第2层,以此类推;
树的高度或深度:树中节点的最大层次; 如上图:树的高度为4
堂兄弟节点:双亲在同一层的节点互为堂兄弟;如上图:H、I互为兄弟节点
节点的祖先:从根到该节点所经分支上的所有节点;如上图:A是所有节点的祖先
子孙:以某节点为根的子树中任一节点都称为该节点的子孙。如上图:所有节点都是A的子孙
森林:由m(m>0)棵互不相交的树的集合称为森林

4.树的表示🎄

树结构相对于线性表要更复杂,它既要保存值域,也要保存结点和结点之间的关系,树的表示法有多种:双亲表示法,孩子表示法,孩子双亲表示法,孩子兄弟表示法等。其中最常用的便是孩子兄弟表示法

typedef int DataType;
struct Node
{
    struct Node* firstChild; //第一个孩子结点
    struct Node* pNextBrother; //指向下一个兄弟结点
    DataType data; //结点中的数据
};

image-20220411204136940

5.什么是二叉树🎄

一棵二叉树是结点的有限集合,该集合由一个根结点加上左子树和右子树组成,集合也可能为空image-20220411210051440

由此可以看出:

  • 二叉树不存在度大于2的结点
  • 二叉树的子树有左右之分,次序不能颠倒,因此二叉树是有序树

Ⅱ.二叉树的介绍✨

1.二叉树的组成🎄

任意二叉树都由以下五种情况复合而成的:

image-20220411210759676

2.普通二叉树🎄

image-20220411210542463

3.特殊二叉树🎄
  • 满二叉树:一个二叉树,如果每一层的节点数都为2,那么它就是满二叉树。也就是说当一个二叉树层数为K时,它的总结点数为2k-1。
  • 完全二叉树:当一个二叉树层数为K时,它的前K-1层结构都为满二叉树,且第K层的结点是有序的,那么它就是完全二叉树。满二叉树是一种特殊的完全二叉树

image-20220411210911237

4.二叉树的性质🎄
  1. 若规定根节点的层数为1,则一棵非空二叉树的第i层上最多有2(i-1)个结点

  2. 若规定根节点的层数为1,则深度为h的二叉树的最大结点数是2h-1

  3. 对任何一棵非空二叉树, 如果度为0其叶结点个数为n0, 度为2的分支结点个数为n2,则有n0=n2+1

  4. 若规定根节点的层数为1,具有n个结点的满二叉树的深度,h=log2(n+1) (ps:log2(n+1)是log以2为底,n+1为对数)

  5. 对于具有n个结点的完全二叉树,如果按照从上至下从左至右的数组顺序对所有节点从0开始编号,则对于序号为i的结点有:

    1.若i>0,i位置节点的双亲序号:(i-1)/2;i=0,i为根节点编号,无双亲节点

    2.若2i+1<n,左孩子序号:2i+1,2i+1>=n否则无左孩子

    3.若2i+2<n,右孩子序号:2i+2,2i+2>=n否则无右孩子

5.二叉树性质题目🎄

第一题:image-20220412144255208
答案:🅱️
解析:叶子结点也就是度为0的数,由性质3可得,度为0的结点永远比度为2的结点多1,所以可以直接得出答案B

第二题:
image-20220412144858869
答案:🅰️

解析:我们假设度为0,1,2的结点各有N0,N1,N2个,那么N0+N1+N2=2N,又因为度为0的结点永远比度为2的结点多1,所以公式可以变成N0+N1+N0-1=2N–>2*N0+N1-1=2N,而完全二叉树的N1结点要么有一个要么没有,最后因为个数要满足整数,所以N1只能是1(如果N1为0最后结果2*N0-1=2N可能为小数),则最终公式为:N0=N,所以选A

第三题:
image-20220412151202592
答案:🅱️

解析:假设高度为h,由性质2可得最多结点为2h-1,最少结点为2h-1-1+1(高度h-1为满二叉树,最后一层只有一个),最后我们将答案带入套一下,看谁531在谁的范围中,谁就是高度,此时210-1=1023,210-1-1+1=512,所以选B

第四题:
image-20220412152152132

答案:🅱️

解析:跟第一题做法一样,假设度为0,1,2的结点各有N0,N1,N2个,那么N0+N1+N2=767,换算一下,2*N0+N1=768,而这个数也不能等于小数,所以选B

6.二叉树的存储结构🎄

二叉树一般有两种结构存储,一种顺序结构,一种链式结构

1.顺序存储

就是用数组来存储,一般只适用于完全二叉树,否则会有空间浪费,二叉树顺序存储在物理结构上是数组逻辑结构上是二叉树

image-20220412153627331

2.链式存储

链表表示一棵二叉树。通常是链表中每个节点由三个域组成,数据域和左右指针域,左右指针分别用来给出该结点左孩子和右孩子所在结点的地址。链式结构又分为二叉链三叉链,我们初阶一般都是二叉链,后面更深入的数据结构红黑树会用到三叉链

image-20220412154256432

typedef int BTDataType;
// 二叉链
struct BinaryTreeNode
{
    struct BinTreeNode* _pLeft; // 指向当前节点左孩子
 	struct BinTreeNode* _pRight; // 指向当前节点右孩子
 	BTDataType _data; // 当前节点值域
};
// 三叉链
struct BinaryTreeNode
{
 	struct BinTreeNode* _pParent; // 指向当前节点的双亲
 	struct BinTreeNode* _pLeft; // 指向当前节点左孩子
 	struct BinTreeNode* _pRight; // 指向当前节点右孩子
 	BTDataType _data; // 当前节点值域
}
;