数据结构——二叉树 1.0

简介: ✅<1>主页:我的代码爱吃辣📃<2>知识讲解:数据结构——二叉树🔥<3>创作者:我的代码爱吃辣☂️<4>开发环境:Visual Studio 2022🏡<5>系统环境:windows 10💬<6>前言:今天来学习一下,数据结构中树以及二叉树的一些相关概念。

🐌 一.树的概念及其结构

🦋(1)树的概念

树是一种非线性的数据结构,它是由n(n>=0)个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的。


有一个特殊的结点,称为根结点,根节点没有前驱结点

除根节点外,其余结点被分成M(M>0)个互不相交的集合T1、T2、……、Tm,其中每一个集合Ti(1<= i<= m)又是一棵结构与树类似的子树。每棵子树的根结点有且只有一个前驱,可以有0个或多个后继

因此,树是递归定义的。


9c56026031e14831befaa8bedeaf44e7.png

3d5b2e9a61d346f6b17e47aa4b2a9d8a.png


注意:树形结构中,子树之间不能有交集,否则就不是树形结构


d1bf4377cf4c4eb580245b97bf976226.png


🐛(2)树的相关概念


568a2e1931324a9abe0eb1b6c5b37de1.png


image.png


 🐜(3)树的表示

树结构相对线性表就比较复杂了,要存储表示起来就比较麻烦了,树的每个结点的孩子个数不确定,所以树的结点在常规表示的时候也是非常的麻烦。

typedef int DataType;
struct Node
{
  struct Node* Child1; // 第一个孩子
  struct Node* Child2; // 第二个孩子
  //
  // ...... 不能确定孩子数
  //
  DataType data; // 结点中的数据域
};

但是这个问题也有很好的解决办法。既然保存值域,也要保存结点和结点之间的关系,实际中树有很多种表示方式如:双亲表示法,孩子表示法、孩子双亲表示法以及孩子兄弟表示法等。我们这里就简单的了解其中最常用的 孩子兄弟表示法。

typedef int DataType;
struct Node
{
    struct Node* _firstChild1; // 第一个孩子结点
    struct Node* _pNextBrother; // 指向其下一个兄弟结点
    DataType _data; // 结点中的数据域
};


cc058845cbc7423da87f207e3ef2a65f.png


说明:左孩子右兄弟表示法,仅仅只用了两个指针,就解决了树的孩子分支不确定的情况下,树的表示问题。


🐝(4)树在实际中的应用

                                                             Linux树状目录结构


a516d58112f74edfb4f084553d1a88a5.png


🪲 二.二叉树的概念及其结构

🐞(1)二叉树的概念

一棵二叉树是结点的一个有限集合,该集合:

1. 或者为空

2. 由一个根节点加上两棵别称为左子树和右子树的二叉树组成


153ef37e99e74d35aad1f0e0b3473678.png


  从上图可以看出:

1. 二叉树不存在度大于2的结点

2. 二叉树的子树有左右之分,次序不能颠倒,因此二叉树是有序树

注意:对于任意的二叉树都是由以下几种情况复合而成的:


4ed64ca8bc434f63a8dad422c689ac4a.png


🦗(2)现实中的二叉树


1478ce10196b4ba8ad98155ebe171abb.png

bbae6dc8888144ffac8474968a047730.png


🕷(3) 特殊的二叉树

1. 满二叉树:一个二叉树,如果每一个层的结点数都达到最大值,则这个二叉树就是满二叉树。也就是说,如果一个二叉树的层数为K,且结点总数是 ,则它就是满二叉树。

2. 完全二叉树:完全二叉树是效率很高的数据结构,完全二叉树是由满二叉树而引出来的。对于深度为K的,有n个结点的二叉树,当且仅当其每一个结点都与深度为K的满二叉树中编号从1至n的结点一一对应时称之为完全二叉树。 要注意的是满二叉树是一种特殊的完全二叉树。


825a42ada7bb4890801f313c3da7bd0f.png


🌸(4)二叉树的性质

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

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

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

4.若规定根节点的层数为1,具有n个结点的满二叉树的深度,h = .

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

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

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

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


性质练习:


1. 某二叉树共有 399 个结点,其中有 199 个度为 2 的结点,则该二叉树中的叶子结点数为( )


A.不存在这样的二叉树


B.200


C.198


D.199


答案:B


[分析]:叶子结点也就是度为 0 的结点,由 性质3 n0 = n2 + 1,所以叶子节点数比度为2的节点数多一。也就是199+1=200。


2.在具有 2n 个结点的完全二叉树中,叶子结点个数为( )

A. n


B. n+1


C. n-1


D n/2


答案:A


[分析]:我们设 此完全二叉树的度为0的结点树为n0,度为1的结点数为n1,度为2的结点个数为n2,所以存在n0 + n1 + n2 = 2n.由于 性质3 n0 = n2 + 1。所以 n2 = n0 -1,所以 2n0 + n1 -1 = 2n,由于是完全二叉树,完全二叉树度为1的结点,只有两种可能 1,0。如果n1 = 0,n0就不在是整数,不合实际。当n1 = 1 的时候,n0 = n,成立。所以叶子结点的数目为 n。


3.一棵完全二叉树的节点数位为531个,那么这棵树的高度为( )

A. 11


B. 10


C. 8


D. 12


答案:B


[分析]:完全二叉树处除了倒数第一层之外,其他层的都是满的。所以如果树的前n-1 层都是满的当n-1=9时,结点数为 2^9-1=511,2^10-1=1023.所以说树的前九层都是满的,第十层不是满的,所以树的高度是10.


🌻最后:

青春由磨砺而出彩,人生因奋斗而升华!


a02350a9ba644d6fa5f7abc7af4ba4aa.jpg


相关文章
|
11天前
|
Java C++
【C++数据结构——树】二叉树的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现二叉树的基本运算。​ 相关知识 创建二叉树 销毁二叉树 查找结点 求二叉树的高度 输出二叉树 //二叉树节点结构体定义 structTreeNode{ intval; TreeNode*left; TreeNode*right; TreeNode(intx):val(x),left(NULL),right(NULL){} }; 创建二叉树 //创建二叉树函数(简单示例,手动构建) TreeNode*create
36 12
|
11天前
|
C++
【C++数据结构——树】二叉树的性质(头歌实践教学平台习题)【合集】
本文档介绍了如何根据二叉树的括号表示串创建二叉树,并计算其结点个数、叶子结点个数、某结点的层次和二叉树的宽度。主要内容包括: 1. **定义二叉树节点结构体**:定义了包含节点值、左子节点指针和右子节点指针的结构体。 2. **实现构建二叉树的函数**:通过解析括号表示串,递归地构建二叉树的各个节点及其子树。 3. **使用示例**:展示了如何调用 `buildTree` 函数构建二叉树并进行简单验证。 4. **计算二叉树属性**: - 计算二叉树节点个数。 - 计算二叉树叶子节点个数。 - 计算某节点的层次。 - 计算二叉树的宽度。 最后,提供了测试说明及通关代
36 10
|
11天前
|
存储 算法 测试技术
【C++数据结构——树】二叉树的遍历算法(头歌教学实验平台习题) 【合集】
本任务旨在实现二叉树的遍历,包括先序、中序、后序和层次遍历。首先介绍了二叉树的基本概念与结构定义,并通过C++代码示例展示了如何定义二叉树节点及构建二叉树。接着详细讲解了四种遍历方法的递归实现逻辑,以及层次遍历中队列的应用。最后提供了测试用例和预期输出,确保代码正确性。通过这些内容,帮助读者理解并掌握二叉树遍历的核心思想与实现技巧。
34 2
|
25天前
|
数据库
数据结构中二叉树,哈希表,顺序表,链表的比较补充
二叉搜索树,哈希表,顺序表,链表的特点的比较
数据结构中二叉树,哈希表,顺序表,链表的比较补充
|
2月前
|
机器学习/深度学习 存储 算法
数据结构实验之二叉树实验基础
本实验旨在掌握二叉树的基本特性和遍历算法,包括先序、中序、后序的递归与非递归遍历方法。通过编程实践,加深对二叉树结构的理解,学习如何计算二叉树的深度、叶子节点数等属性。实验内容涉及创建二叉树、实现各种遍历算法及求解特定节点数量。
112 4
|
2月前
|
C语言
【数据结构】二叉树(c语言)(附源码)
本文介绍了如何使用链式结构实现二叉树的基本功能,包括前序、中序、后序和层序遍历,统计节点个数和树的高度,查找节点,判断是否为完全二叉树,以及销毁二叉树。通过手动创建一棵二叉树,详细讲解了每个功能的实现方法和代码示例,帮助读者深入理解递归和数据结构的应用。
171 8
|
3月前
|
存储 算法 关系型数据库
数据结构与算法学习二一:多路查找树、二叉树与B树、2-3树、B+树、B*树。(本章为了解基本知识即可,不做代码学习)
这篇文章主要介绍了多路查找树的基本概念,包括二叉树的局限性、多叉树的优化、B树及其变体(如2-3树、B+树、B*树)的特点和应用,旨在帮助读者理解这些数据结构在文件系统和数据库系统中的重要性和效率。
39 0
数据结构与算法学习二一:多路查找树、二叉树与B树、2-3树、B+树、B*树。(本章为了解基本知识即可,不做代码学习)
|
3月前
|
存储 算法 搜索推荐
数据结构与算法学习十七:顺序储存二叉树、线索化二叉树
这篇文章主要介绍了顺序存储二叉树和线索化二叉树的概念、特点、实现方式以及应用场景。
50 0
数据结构与算法学习十七:顺序储存二叉树、线索化二叉树
|
3月前
|
Java
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(二)
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(二)
38 1
|
3月前
|
算法 Java C语言
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(一)
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(一)
34 1

热门文章

最新文章