| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 化解数据结构----树与二叉树 知识梳理 + 习题详解 -> 正文阅读 |
|
[数据结构与算法]化解数据结构----树与二叉树 知识梳理 + 习题详解 |
🔍树与二叉树 知识梳理 + 习题详解一、树🔍1.基本定义🎯 树:是N(N≥0)个结点的有限集合 2.基本术语
🎯 树的定义是递归的,是一种递归的数据结构。 3.实例分析树3.1祖先节点&双亲节点:💌根结点A到K的唯一路径上的任意结点,称为K的祖先结点。 如结点B是K的祖先节点,K是B的子孙结点。 3.2兄弟节点:💎根A是树中唯一没有双亲的结点。有相同双亲的结点称为兄弟节点,如K和L有相同的双亲结点E,即K和L是兄弟结点。 3.3结点的度&树的度:💎树中一个结点的子结点个数称为该结点的度,树中结点最大度数称为树的度。 如B的度为2,但是D的度为3,所以该树的度为3.(简单来说,就是结点的度中最大的值就是树的度) 3.4分支结点&叶子结点💎度大于0的结点称为分支结点(又称为非终端结点);度为0(没有子女结点)的结点称为叶子结点(又称终端结点)。在分支结点中,每个结点的分支数就是该节点的度。 3.5结点的深度、高度、层次💎结点的深度是从根节点开始自顶向下逐层累加的。 4.有序树和无序树💎有序树:树中结点的子树从左到右是有次序的,不能交换。有序树中,一个结点其子结点从左到右顺序出现是有关联的。反之称为无序树。在上图中,如果将子结点的位置互换,则变为一棵不同的树。 5.路径和路径长度💎树中两个结点之间的路径是由这两个节点之间所经过的结点序列构成的,而路径长度是路径上所经过的边的个数。A和K的路径长度为3.路径为B,E。 6.森林💎森林是m棵互不相交的树的集合。森林的概念和树的概念十分相近,因为只要把树的根节点删掉之后就变成了森林。反之,只要给n棵独立的树加上一个结点,并且把这n棵树作为该结点的子树,那么森林就变成了树。 7.树的基本性质(必看)🚀1.树中结点数等于所有结点的度数+1(+1加的是根结点) 🚀2.度为m的树中第i层上至多有m^(i - 1)个结点(i >=1) 二、二叉树🔍1. 定义💌定义:把满足以下两个条件的树型结构叫做二叉树(Binary Tree): 2.二叉树的五种形态🍻图(a)所示为一棵空的二叉树; 3.满二叉树&完全二叉树&非完全二叉树💌满二叉树: 深度为 k 且有 2^k -1 个结点的二叉树。在满二叉树中,每层结点都是满的, 即每层结点都具有最大结点数。如下图(a)所示的二叉树即为一棵满二叉树。 💌完全二叉树: 深度为 k,结点数为 n 的二叉树,如果其结点 1~n 的位置序号分别与满 二叉树的结点 1~n 的位置序号一一对应,则为完全二叉树,如下图(b)所示。 非完全二叉树: 序号不和满二叉树的序号一一对应。如下图(c)和(d) 4. 二叉树的基本操作二叉树(Binary Tree),以下我们简称为bt💌💌💌 4.二叉树的存储结构4.1 顺序存储按满二叉树的结点层次编号,依次存放二叉树中的数据元素。 4.2 链式存储对于任意的二叉树来说,每个结点只有两个孩子,一个双亲结点。可以设计每个结点至少包 括三个域:数据域、左孩子域和右孩子域,如下图所示。 C语言实现:
5.二叉树的性质🏆性质 1:在二叉树的第 i 层上至多有 2^(i-1)个结点(i≥1)。 三、树的遍历(二叉树)🔍遍历定义:指按某条搜索路线遍访每个结点且不重复(又称周游)。
1.先序遍历C实现代码:
非递归写法:
2.中序遍历C实现代码:
3.后序遍历后序遍历的性质:对于一颗树,最后的那一个结点是根节点
4.二叉树的建立
5.计算二叉树结点总数如果是空树,则结点个数为0;
6.计算二叉树叶子结点总数如果是空树,则叶子结点个数为0; 否则,为左子树的叶子结点个数+右子树的叶子结点个数。
7.计算二叉树深度如果是空树,则深度为0;
8.线索二叉树对于一个二叉树来说,其二叉链表表示形式中正好有两个指针域,一个左子树指针域,一个右子树指针域。并且对于一个有 n 个节点的二叉链表, 每个节点有指向左右孩子的两个指针域,所以共是 2n 个指针域。而 n 个节点的二叉树一共有 n-1 条分支数,也就是说,其实是存在 2n-(n-1) = n+1个空指针域。 那么根据遍历来进行线索化的方式也就有四种方式:先序线索化、中序线索化、后序线索化、层序线索化,其实严格意义上来说,除了遍历的顺序不同,其他的没什么太大的区别。对于线索化来将也是一样的。 所以,如果这个节点的左指针域是空的,那么就让其指向前驱,如果这个节点的右指针域为空,那么就让其指向后继, 所以,四种线索化的示意图可以表示为下图这样。(其中 红色线条 表示前驱、 蓝色线条 表示为后继,均称为 线索。) 四、森林🔍二叉树转森林:左指针指的是左孩子,右指针指的是兄弟,这样就避免了一颗多叉树需要像二叉树一样的每一个结点使用多个指针的情况了。 五、Huffman树🔍哈夫曼树又称最优二叉树,是一种带权路径长度最短的二叉树。 六 作业练习🔍(1)把一棵树转换为二叉树后,这棵二叉树的形态是( )。 A.唯一的 B.有多种 C.有多种,但根结点都没有左孩子 D.有多种,但根结点都没有右孩子 答案:A 解释:因为二叉树有左孩子、右孩子之分,故一棵树转换为二叉树后,这棵二叉树的形态是唯一的。 (2)由3个结点可以构造出多少种不同的二叉树?( ) A.2 B.3 C.4 D.5 答案:D (3)一棵完全二叉树上有1001个结点,其中叶子结点的个数是( )。 A.250 B. 500 C.254 D.501 答案:D 解释:设度为0结点(叶子结点)个数为A,度为1的结点个数为B,度为2的结点个数为C,有A=C+1,A+B+C=1001,可得2C+B=1000,由完全二叉树的性质可得B=0或1,又因为C为整数,所以B=0,C=500,A=501,即有501个叶子结点。 (4)一个具有1025个结点的二叉树的高h为( )。 A.11 B.10 C.11至1025之间 D.10至1024之间 答案:C 解释:若每层仅有一个结点,则树高h为1025;且其最小树高为 ?log21025? + 1=11,即h在11至1025之间。 (5)深度为h的满m叉树的第k层有( )个结点。(1=<k=<h) A.mk-1 B.mk-1 C.mh-1 D.mh-1 答案:A 解释:深度为h的满m叉树共有mh-1个结点,第k层有mk-1个结点。 (6)利用二叉链表存储树,则根结点的右指针是( )。 A.指向最左孩子 B.指向最右孩子 C.空 D.非空 答案:C 解释:利用二叉链表存储树时,右指针指向兄弟结点,因为根节点没有兄弟结点,故根节点的右指针指向空。 (7)对二叉树的结点从1开始进行连续编号,要求每个结点的编号大于其左、右孩子的编号,同一结点的左右孩子中,其左孩子的编号小于其右孩子的编号,可采用( )遍历实现编号。 A.先序 B. 中序 C. 后序 D. 从根开始按层次遍历 答案:C 解释:根据题意可知按照先左孩子、再右孩子、最后双亲结点的顺序遍历二叉树,即后序遍历二叉树。 (8)若二叉树采用二叉链表存储结构,要交换其所有分支结点左、右子树的位置,利用( )遍历方法最合适。 A.前序 B.中序 C.后序 D.按层次 答案:C 解释:后续遍历和层次遍历均可实现左右子树的交换,不过层次遍历的实现消耗比后续大,后序遍历方法最合适。 (9)在下列存储形式中,( )不是树的存储形式? A.双亲表示法 B.孩子链表表示法 C.孩子兄弟表示法 D.顺序存储表示法 答案:D 解释:树的存储结构有三种:双亲表示法、孩子表示法、孩子兄弟表示法, 其中孩子兄弟表示法是常用的表示法,任意一棵树都能通过孩子兄弟表示法转换为二叉树进行存储。 (10)一棵非空的二叉树的先序遍历序列与后序遍历序列正好相反,则该二叉树一定满足( )。 A.所有的结点均无左孩子 B.所有的结点均无右孩子 C.只有一个叶子结点 D.是任意一棵二叉树 答案:C 解释:因为先序遍历结果是“中左右”,后序遍历结果是“左右中”,当没有左子树时,就是“中右”和“右中”;当没有右子树时,就是“中左”和“左中”。则所有的结点均无左孩子或所有的结点均无右孩子均可,所以A、B不能选,又所有的结点均无左孩子与所有的结点均无右孩子时,均只有一个叶子结点,故选C。 (11)设哈夫曼树中有199个结点,则该哈夫曼树中有( )个叶子结点。 A.99 B.100 C.101 D.102 答案:B 解释:在哈夫曼树中没有度为1的结点,只有度为0(叶子结点)和度为2的结点。设叶子结点的个数为n0,度为2的结点的个数为n2,由二叉树的性质n0=n2+1,则总结点数n= n0+n2=2*n0-1,得到n0=100。 (12)若X是二叉中序线索树中一个有左孩子的结点,且X不为根,则X的前驱为( )。 A.X的双亲 B.X的右子树中最左的结点 C.X的左子树中最右结点 D.X的左子树中最右叶结点 答案:C (13)引入二叉线索树的目的是( )。 A.加快查找结点的前驱或后继的速度 B.为了能在二叉树中方便的进行插入与删除 C.为了能方便的找到双亲 D.使二叉树的遍历结果唯一 答案:A (14)设F是一个森林,B是由F变换得的二叉树。若F中有n个非终端结点,则B中右指针域为空的结点有( )个。 A.n?1 B.n C.n + 1 D.n + 2 答案:C (15)n(n≥2)个权值均不相同的字符构成哈夫曼树,关于该树的叙述中,错误的是( )。 A.该树一定是一棵完全二叉树 B.树中一定没有度为1的结点 C.树中两个权值最小的结点一定是兄弟结点 D.树中任一非叶结点的权值一定不小于下一层任一结点的权值 答案:A 解释:哈夫曼树的构造过程是每次都选取权值最小的树作为左右子树构造一棵新的二叉树,所以树中一定没有度为1的结点、两个权值最小的结点一定是兄弟结点、任一非叶结点的权值一定不小于下一层任一结点的权值。 🌲🌲🌲 好啦,这就是今天要分享给大家的全部内容了
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/1 23:18:09- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |