什么是单支树?
一、什么是单支树
单支树是非叶子节点只有一个孩子节点,且方向一致的特殊二叉树。单支树指的是只有一个孩子并且方向一致,就是每个结点非常多只有一个孩子结点,其实就是链表。
二叉树是另一种树形结构,其特点是每个结点至多只有两棵子树( 即二叉树中不存在度大于2的结点),并且二叉树的子树有左右之分,其次序不能任意颠倒。
与树相似,二叉树也以递归的形式定义。二叉树是n (n≥0) 个结点的有限集合:
或者为空二叉树,即n=0。
或者由一个根结点和两个互不相交的被称为根的左子树和右子树组成。左子树和右子树又分别是一棵二叉树。
二叉树是有序树,若将其左、右子树颠倒,则成为另一棵不同的二叉树。即使树中结点只有一棵子树,也要区分它是左子树还是右子树。
延伸阅读:
二、几个特殊的二叉树
(1)斜树
所有的结点都只有左子树的二叉树叫左斜树。所有结点都是只有右子树的二叉树叫右斜树。这两者统称为斜树。
(2)满二叉树棵高度为h,且含有2 h − 1 2^h-12h−1个结点的二叉树称为满二叉树,即树中的每层都含有非常多的结点。满二叉树的叶子结点都集中在二叉树的最下一层,并且除叶子结点之外的每个结点度数均为2 22。可以对满二叉树按层序编号:约定编号从根结点(根结点编号为1 11)起,自上而下,自左向右。这样,每个结点对应一个编号,对于编号为i的结点,若有双亲,则其双亲为i / 2 i/2i/2,若有左孩子,则左孩子为2 i 2i2i;若有右孩子,则右孩子为2 i + 1 2i+12i+1。

猜你喜欢LIKE
相关推荐HOT
更多>>
为什么要放弃Lombok?
一、为什么要放弃Lombok1、JDK版本问题当用户想要将现有项目的JDK从Java 8升级到Java 11时,用户会发现Lombok不能正常工作了。于是不得不将所有...详情>>
2023-10-15 23:30:56
ios软件开发用什么工具?
一、ios软件开发工具1、Designing在应用程序的设计阶段有帮助的工具a)Free iOS PSD 是PSD格式的免费模板的集合b) Live View它有助于检查应用程...详情>>
2023-10-15 22:46:20
软件架构如何能够满足ASPICE流程?
一、软件架构如何能够满足ASPICE流程架构的用途是把整个产品划分为更为细节的板块:软件、硬件、通信等。在这个基础上软件整体将按照用途、功能...详情>>
2023-10-15 21:25:33
开发一个生鲜商城APP软件可以解决哪些问题?
1、通过便捷的购物渠道节省用户的时间现在,在社会管理、生活和学习的压力下,许多企业用户的时间越来越少。更重要的是,他们可以节省时间做自...详情>>
2023-10-15 20:37:15热门推荐
UML有哪些常用关系?
沸Spring和Spring Boot有什么区别?
热为什么要放弃Lombok?
热云下载和本地重新安装有什么区别?
新为什么Java中“1000==1000”为false,而”100==100“为true?
CameraX 1.1 有哪些新的特性发布?
ios软件开发用什么工具?
为什么编程语言中没有占用5个字节的int40?
c++的数据结构中,某个结点root的表示中!root和root!=nullptr的区别在哪?
链表的基本操作是什么?
Java中的泛型与C中的泛型有区别?
为什么二叉堆只能删除堆顶元素?
什么是单支树?
软件架构如何能够满足ASPICE流程?
技术干货






