【二叉树】

文章目录

  • 树形结构
    • 注意要点
    • 细分概念
    • 树在生活中的应用
  • 二叉树
    • 什么是二叉树
    • 二叉树特点:
    • 两种特殊的二叉树
    • 二叉树的性质
    • 二叉树性质的练习
    • 二叉树的存储
    • 二叉树的遍历
      • 前序遍历
      • 中序遍历
      • 后序遍历
      • 遍历练习


树形结构

树是一种非线性的数据结构,它具有以下的特点:

  • 有一个特殊的结点,称为根结点,根结点没有前驱结点
  • 除根结点外,其余结点被分成M(M >0)个互不相交的集合T1、T2、…、Tm,其中每一个集合Ti (1 <= i <=m)又是一棵与树类似的子树。每棵子树的根结点有且只有一个前驱,可以有0个或多个后继
  • 树是递归定义的。
    在这里插入图片描述

注意要点

如果子数之间有交集就不是树形结构

下面这三种都不是树形结构
在这里插入图片描述

  • 子树是不相交
  • 除了根结点以外,每个结点有且仅有一个父节点
  • 一棵N个结点的树,有N-1个结点

细分概念

在这里插入图片描述

  • 结点的度:一个结点含有子树的个数称为该结点的度; 如上图:A的度为6
  • 树的度:一棵树中,所有结点度的最大值称为树的度; 如上图:树的度为6
  • 叶子结点或终端结点:度为0的结点称为叶结点; 如上图:B、C、H、I…等节点为叶结点
  • 双亲结点或父结点:若一个结点含有子结点,则这个结点称为其子结点的父结点; 如上图:A是B的父结点
  • 孩子结点或子结点:一个结点含有的子树的根结点称为该结点的子结点; 如上图:B是A的孩子结点
  • 根结点:一棵树中,没有双亲结点的结点;如上图:A 结点的层次:从根开始定义起,根为第1层,根的子结点为第2层,以此类推
  • 树的高度或深度:树中结点的最大层次; 如上图:树的高度为4

树在生活中的应用

电脑文件夹(目录和文件),是一层一层打开的,C盘就是根节点,打开有很多结点。

二叉树

什么是二叉树

二叉树是有限集合

  • 要么为空
  • 要么是由一个根结点,加上两棵叫做左子树和右子树的二叉树组成

在这里插入图片描述

二叉树特点:

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

二叉树只有以下这种形式:
在这里插入图片描述

两种特殊的二叉树

  1. 满二叉树: 一棵二叉树,如果每层的结点数都达到最大值,则这棵二叉树就是满二叉树。也就是说,如果一棵二叉树的层数为K,且结点总数是,则它就是满二叉树。 注意它是一种特殊的完全二叉树。
  2. 完全二叉树: 完全二叉树是效率很高的数据结构,完全二叉树是由满二叉树而引出来的。如果从上到下,从左到右,结点都是依次存放的,那么就是完全二叉树。
    在这里插入图片描述
    下面这个就不是二叉树了
    在这里插入图片描述

二叉树的性质

1.若规定根结点的层数为1,则一棵非空二叉树的第i层上最多有2^(i-1) (i>0)个结点
在这里插入图片描述
2.若规定只有根结点的二叉树的深度为1,则深度为K的二叉树的最大结点数是2^(k-1) (k>=0)
跟第一条差不多一样,求最深结点的个数。
3. 对任何一棵二叉树, 如果其叶结点个数为 n0, 度为2的非叶结点个数为 n2,则有n0=n2+1
结论:叶子结点个数比度为2的非叶结点个数多一个。
在这里插入图片描述
在这里插入图片描述
5.对于具有n个结点的完全二叉树,如果按照从上至下从左至右的顺序对所有节点从0开始编号,则对于序号为i的结点有:
若i > 0,双亲序号:(i-1)/2;i=0,i为根结点编号,无双亲结点
若2i+1 < n,左孩子序号:2i+1,否则无左孩子
若2i+2 < n,右孩子序号:2i+2,否则无右孩子
在这里插入图片描述

二叉树性质的练习

  1. 某二叉树共有 399 个结点,其中有 199 个度为 2 的结点,则该二叉树中的叶子结点数为( )
    A 不存在这样的二叉树
    B 200
    C 198
    D 199
    答案:B
    叶子结点个数 = 度为2的结点个数+1

2.在具有 2n 个结点的完全二叉树中,叶子结点个数为( )
A n
B n+1
C n-1
D n/2
在这里插入图片描述

3.一个具有767个节点的完全二叉树,其叶子节点个数为()
A 383
B 384
C 385
D 386
在这里插入图片描述
4.一棵完全二叉树的节点数为531个,那么这棵树的高度为( )
A 11
B 10
C 8
D 12
依据第四条规则得出

二叉树的存储

二叉树的存储结构分为:顺序存储和类似于链表的链式存储

二叉树的链式存储是通过一个一个的节点引用起来的,常见的表示方式有:

// 孩子表示法
class Node {
int val; // 数据域
Node left; // 左孩子的引用,常常代表左孩子为根的整棵左子树
Node right; // 右孩子的引用,常常代表右孩子为根的整棵右子树
}

在这里插入图片描述

二叉树的遍历

前序遍历

访问根结点—>根的左子树—>根的右子树

从根节点A遍历并打印,继续遍历左子树B并打印,此时,左子树成为一个根节点,继续遍历它的左子树D并打印,而这棵左子树D又是根结点,又向它的左子树遍历,发现为空,往右子树遍历,为空,则D树遍历完(也就是B的左子树遍历完),然后遍历B的右子树,为空,则B树遍历完,(也就是A的左子树遍历完),继续遍历A的右子树
在这里插入图片描述
A B D C E F

中序遍历

左子树–根–右子树

在这里插入图片描述
D B A E C F

从A进入,(还不能打印A,因为要先遍历完左子树才到根)往左子树B遍历,左子树B变成了根节点,继续遍历B的左子树D,D变成了根节点,遍历D的左子树发现为空,(这说明左子树遍历完了)返回遇到根节点D,打印根节点D,(遍历完根,到右子树了)D的右子树为空,那么D这个树遍历完了,返回去遇到根节点B并打印,继续遍历右节点发现为空,又返回去遇到根节点A,打印A。(过程的大概就是如此)

后序遍历

左子树–右子树–根

在这里插入图片描述
D B E F C A
从A开始往左子树遍历B,又从B往左子树遍历D,又从D往左子树遍历发现为空,又遍历右子树发现为空,返回到根D,打印D,B的左子树遍历完了,遍历B的右子树,发现为空,返回根B,打印B,A的左子树遍历完了,往右子树C遍历,又往C的左字数遍历E,又往E的左子树遍历,为空,往E的右子树遍历,为空,返回根F,打印F,C的右子树遍历完了,打印根C,返回到A,A的左右子树都遍历完了,终于打印最后的根A。

遍历练习

在这里插入图片描述
2.某完全二叉树按层次输出(同一层从左到右)的序列为 ABCDEFGH 。该完全二叉树的前序序列为()
A: ABDHECFG B: ABCDEFGH C: HDBEAFCG D: HDEBFGCA
在这里插入图片描述
3.二叉树的先序遍历和中序遍历如下:先序遍历:EFHIGJK;中序遍历:HFIEJKG.则二叉树根结点为()
A: E B: F C: G D: H
在这里插入图片描述
4.3.设一课二叉树的中序遍历序列:badce,后序遍历序列:bdeca,则二叉树前序遍历序列为()
A: adbce B: decab C: debac D: abcde

在这里插入图片描述4.某二叉树的后序遍历序列与中序遍历序列相同,均为 ABCDEF ,则按层次输出(同一层从左到右)的序列为()
A: FEDCBA B: CBAFED C: DEFCBA D: ABCDEF

解析:从后序遍历得出根节点是F,所以按层次输出第一个一定是F,因此答案选A。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/256095.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

class059 建图、链式前向星、拓扑排序【算法】

class059 建图、链式前向星、拓扑排序【算法】 code1 建图 package class059;import java.util.ArrayList; import java.util.Arrays;public class Code01_CreateGraph {// 点的最大数量public static int MAXN 11;// 边的最大数量// 只有链式前向星方式建图需要这个数量// 注…

Unity 关于Ray、RaycastHit、Raycast及其使用

Unity中&#xff0c;我们要进行物理模拟和碰撞检测时&#xff0c;有三个重要的概念Ray、RaycastHit、Raycast。 其中&#xff0c;Ray可以理解为射线&#xff0c;它是一条从起点沿着特定方向延伸的无限长线段。 它的语法是&#xff1a; Ray(Vector3 origin, Vector3 directio…

多路径传输(MPTCP MPQUIC)数据包调度研究总结

近些年来&#xff0c;以5G和Wifi6为代表的无线通信技术发展迅速&#xff0c;并已经在全世界实现了大规模部署。此外&#xff0c;智能手机等移动设备不断迭代更新&#xff0c;其网络通信能力也持续演进&#xff0c;使得应用同时利用多个不同网卡在多条不同物理链路上&#xff08…

2023-2024-1-高级语言程序设计-第2次月考编程题

注&#xff1a;此前已发布过的题解不再发布&#xff08;原题请在下面位置进行搜索&#xff09;。 7-1-2 排序(算法任意) 本题要求将给定的n个整数从大到小排序后输出&#xff08;可使用任意排序算法&#xff09;。 输入格式: 输入第一行给出一个不超过10的正整数n。第二行给…

【Docker】Swarm的ingress网络

Docker Swarm Ingress网络是Docker集群中的一种网络模式&#xff0c;它允许在Swarm集群中运行的服务通过一个公共的入口点进行访问。Ingress网络将外部流量路由到Swarm集群中的适当服务&#xff0c;并提供负载均衡和服务发现功能。 在Docker Swarm中&#xff0c;Ingress网络使…

如何使用HadSky搭配内网穿透工具搭建个人论坛并发布至公网随时随地可访问

文章目录 前言1. 网站搭建1.1 网页下载和安装1.2 网页测试1.3 cpolar的安装和注册 2. 本地网页发布2.1 Cpolar临时数据隧道2.2 Cpolar稳定隧道&#xff08;云端设置&#xff09;2.3 Cpolar稳定隧道&#xff08;本地设置&#xff09;2.4 公网访问测试 总结 前言 经过多年的基础…

ORA-600 kcbzib_kcrsds_1一键恢复

一个19c库由于某种原因redo损坏强制打开库报ORA-600 kcbzib_kcrsds_1错误 SQL> startup mount pfile?/database/pfile.txt; ORACLE instance started. Total System Global Area 859830696 bytes Fixed Size 9034152 bytes Variable Size 5…

Android平板还能编程?Ubuntu本地安装code-server远程编程写代码

文章目录 1.ubuntu本地安装code-server2. 安装cpolar内网穿透3. 创建隧道映射本地端口4. 安卓平板测试访问5.固定域名公网地址6.结语 1.ubuntu本地安装code-server 准备一台虚拟机,Ubuntu或者centos都可以&#xff0c;这里以VMwhere ubuntu系统为例 下载code server服务,浏览器…

TCP通讯

第二十一章 网络通信 本章节主要讲解的是TCP和UDP两种通信方式它们都有着自己的优点和缺点 这两种通讯方式不通的地方就是TCP是一对一通信 UDP是一对多的通信方式 接下来会一一讲解 TCP通信 TCP通信方式呢 主要的通讯方式是一对一的通讯方式&#xff0c;也有着优点和缺点…

Spring AOP从入门到精通

目录 1. AOP的演化过程 1. 代理模式 2. 动态代理 2.1 JDK动态代理 2.2 Cglib动态代理 3. Spring模式 3.1 ProxyFactory 3.2 ProxyFactoryBean 3.3 AbstractAutoProxyCreator 2. Spring AOP抽象 1. 核心术语 1.1 连接点(JoinPoint) 1.2 切点(Pointcut) 1.3 增强(Ad…

使用Java网络编程,窗口,线程,IO,内部类等实现多人在线聊天1.0

1.整体思路 思路图 整体思路如上: 涉及知识点:线程网络编程集合IO等 TCP 协议 2.代码实现过程 服务端 import javax.swing.*; import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.KeyAdapter; import jav…