问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

C语言数据结构之二叉树的基本知识

创作时间:
作者:
@小白创作中心

C语言数据结构之二叉树的基本知识

引用
CSDN
1.
https://m.blog.csdn.net/2401_85828611/article/details/143833050

1.树的定义

非线性数据结构(线性的数据结构:顺序表、链表和队列),结构类似倒过来的树(根朝上叶朝下)

树是递归定义的

任何一棵树都由两部分构成:根和子树,子树又由根和子树构成

一些细碎的概念

用亲缘关系来描述
注:有★为重要概念
结点的度:一个结点含有的子树的个数称为该结点的度(或者说:一个结点的度是指该结点拥有的子结点的数量); 如上图:A的为6
叶结点或终端结点:度为0的结点称为叶结点; 如上图:B、C、H、I...等结点为叶结点
非终端结点或分支结点:度不为0的结点; 如上图:D、E、F、G...等结点为分支结点
双亲结点或父结点:若一个结点含有子结点,则这个结点称为其子结点的父结点; 如上图:A是B的父结点
孩子结点或子结点:一个结点含有的子树的根结点称为该结点的子结点; 如上图:B是A的孩子结点
兄弟结点:具有相同父结点的结点互称为兄弟结点; 如上图:B、C是兄弟结点
树的度:一棵树中,最大的结点的度称为树的度; 如上图:树的度为6
结点的层次:从根开始定义起,根为第1层,根的子结点为第2层,以此类推;
树的高度或深度:树中结点的最大层次; 如上图:树的高度为4(注:按认知角度来说,空树的高度为0,因此从1开始算:1,2,3,4,..,n)
堂兄弟结点:双亲在同一层的结点互为堂兄弟;如上图:H、I互为兄弟结点
结点的祖先:从根到该结点所经分支上的所有结点;如上图:A是所有结点的祖先
例如:Q的祖先:A,E,J,Q
子孙:以某结点为根的子树中任一结点都称为该结点的子孙。如上图:所有结点都是A的子孙
森林:由m(m>0)棵互不相交的树的集合称为森林;
两个节点之间的路径:两个节点之间的最短路径
路径长度:两点路径中边的个数

2.树的判断法则

树?非树?

答案:都不是树
分析:以第一张图说明:C->D(C为根,D为子树)D->C(D为根,C为子树),矛盾(递归死循环)
因此子树不能相交!

树结点结构的定义

自然想到的定义方法

struct TreeNode
{
    struct TreeNode* child1;
    struct TreeNode* child2;
    struct TreeNode* child3;
    ......
    struct TreeNode* childN;
    int data;
};  

或者使用数组

#define N 10
struct TreeNode
{
    struct TreeNode* children[N];
    int data;
};  

上述两种定义的方法不高效,需要手动设置多个结点,而且只针对于N已知的情况,其实使用"左孩子+右兄弟"的方法更简单

左孩子+右兄弟定义

例如下面这个二叉树
用"左孩子+右兄弟"方法画图

3.树的应用:文件系统

打开文件管理器
显然是一个树形结构

4.树的特殊形式:二叉树

要求:根结点下最多两个子树(左子树和右子树,次序不可颠倒,为有序树)即0<=度<=2

5.特殊的两类二叉树

满二叉树

一个二叉树,如果每一个层的结点数都达到最大值,则这个二叉树就是满二叉树.也就是说,如果
一个二叉树的层数为k,且结点总数是
,则它就是满二叉树
结点总数的计算方法:等比求和
可以推出:结点个数为n的满二叉树的高度为

完全二叉树

完全二叉树是效率很高的数据结构,完全二叉树是由满二叉树而引出来的.对于深度为K的,有n个结点的二叉树,当且仅当其每一个结点都与深度为K的满二叉树中编号从1至n的结点一一对应时称之为完全二叉树.
要注意的是满二叉树是一种特殊的完全二叉树.
即前k-1层都是满的,最后一层要求从左到右是连续的(结点挨着,不能有空缺)也可理解为相当于在慢二叉树的基础上从后往前依次删掉一些结点

完全二叉树和满二叉树之间的关系

高度为h的完全二叉树结点的数量范围

最少结点个数:第h层1个结点:
最多结点个数:第h层结点填满(满二叉树):
因此★结点的数量范围为
同理,如果给出一个二叉树的所有结点n的个数,可以反推出树的高度
h取
之间的整数即可

6.两个性质

度为0和度为1的结点个数之间的关系

对于非空树,度为0的结点的个数永远比度为2的结点个数多一个
设度为0的结点(叶结点)的个数为
,度为0的结点的个数为
,则有

结点个数和边数的关系

会发现:除了根节点,其余结点都配有一个边,因此结点个数==边数+1

7.二叉树概念选择题

1.在具有 2n 个结点的完全二叉树中,叶子结点个数为( )
A n
B n+1
C n-1
D n/2

2.一棵完全二叉树的结点数位为531个,那么这棵树的高度为( )
A 11
B 10
C 8
D 12

3.一个具有767个结点的完全二叉树,其叶子结点个数为()
A 383
B 384
C 385
D 386

答案:1.A 2.B 3.B

分析:
解:
1.设二叉树所有结点的个数为
,度为0的结点的个数为
,度为1的结点的个数为
,度为0的结点的个数为
一定有
,又由二叉树的一个性质可知
现求
的值:题目要求完全二叉树的所有结点个数为2n,是偶数
例如下图,显然
值为1
则有这三式:
;
;
因此
,选A

度为1的规律

满二叉树
,完全二叉树
为1或0
其中对于完全二叉树,所有结点个数为奇数时,
所有结点个数为偶数时,

2.用高度为h的完全二叉树结点的数量范围结论做题
,取h=10,则
,531在范围内,选B

3.用度为1的规律做题,n=767,为奇数,因此
,因此
,又因为
,则

8.笔试题

来源:2024年淘天集团春招研发岗笔试
分析:为什么会有最多和最少的情况出现?
答案:BC

© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号