【数据结构】二叉树的基本知识

news2024/11/15 20:11:04

目录

    • 前言
    • 一、树
        • 1、树的相关概念
          • (1)结点
          • (2)结点的度
          • (3)叶结点
          • (4)分支结点
          • (5)父亲结点
          • (6)子节点
          • (7)树的度
          • (8)结点的层次
          • (9)树的深度(高度)
          • (10)结点的祖先
          • (11)子树
        • 2、树的表示方法
    • 二、二叉树
        • 1、特殊的二叉树
          • (1)满二叉树
          • (2)完全二叉树

前言

前面我们学习的都是一些线性的数据结构,比顺序表,链表,栈和队列,逻辑结构比较简单,今天我们重点学习的是一种非线性的数据结构,就是树形结构。

一、树

在现实生活中我们都看到过树,如下图,所以对树的形状会有一个基本的认知
在这里插入图片描述
但是在数据结构这门课中我们学习的树可就不是长上面这个样子了,而是下面这个奇怪的样子:
在这里插入图片描述
在这里插入图片描述

1、树的相关概念

(1)结点

每一个树都是由一个个小小的单元组成,在数据结构中,我们将这样的小单元称为结点。
在这里插入图片描述
像上面ABCDEF都是这棵树的结点。

(2)结点的度

每一个结点都是相当于一棵子树的根,而根又会有很多的分支,在数据结构中,一个结点有多少个分支,我们就说这个结点的度为多少。比如:
在这里插入图片描述
像上面这个图中,A这个结点有三个分支,就说明A的度为3。E和F这两个结点没有分支,我们就说这两个结点的度为0。

(3)叶结点

我们将度为0的结点称为叶子结点,或简称为叶节点。如下图中的EF结点度为0,所以它们为叶节点。
在这里插入图片描述

(4)分支结点

与叶子结点相反,度不为0的结点我们称为分支结点,如下图中AC结点的度不为0,所以AC结点为分支结点。
在这里插入图片描述

(5)父亲结点

如果一个结点含有分支,也就是包含子树,则我们将这个结点称为其子树的父亲结点或双亲结点,后面我们是用parent来表示。如下图中的A结点有三个分支BCD结点,所以我们成A结点是BCD结点的父亲结点。
在这里插入图片描述

(6)子节点

一个结点含有的子树的根结点我们称为这个结点的子节点,就是我们要知道一个子树是由自己的根节点和另外的子树构成的。下图中:A包含BCD三个子树,BCD三个结点分别为对应子树的根节点,所以我们成BCD结点为A结点的子节点,后面我们是用child来表示。
在这里插入图片描述

(7)树的度

一棵树中所有结点中度最大的结点的度我们称为这棵树的度,下图中:显然A结点的度最大,是3,所以我们说这棵树的度为3。
在这里插入图片描述

(8)结点的层次

从这棵树的根节点开始定义,我们说根结点是第一层,其子树的根节点为第三层,以此类推。下图中:A为第一层,BCD为第二层,EF为第三层。
在这里插入图片描述

(9)树的深度(高度)

一棵树最大的层次就是这棵树的深度(高度),如下图中:这棵树的最大层次为3,所以我们说这棵树的深度(高度)为3。
在这里插入图片描述

(10)结点的祖先

从根到该节点所经分支上的所有结点都称为该节点的祖先,注:在OJ题中一个结点也可以算成其自己的祖先。如下图中:从A到E,经历了ACE,所以我们成ACE结点都是E结点的祖先。
在这里插入图片描述

(11)子树

任意一个结点都可以说是由根节点和其自己的子树组成

2、树的表示方法

上面介绍的树是树中的一种特殊的结构,二叉树,二叉树中每个节点的度最大为2,但是树就不一样了,树中的每一个结点的度是不确定的,可多可少。所以表示起来会比较麻烦,在这里我们学习一种比较优秀的表示方法:孩子兄弟表示法,这个方法需要和前面学习的链表结合起来,首先需要定义树中结点的结构

// 定义树存储的数据类型
typedef int TreeDataType;

// 定义一棵树的结点的结构
struct TreeNode
{
	TreeDataType data;
	struct TreeNode* first_child;
	struct TreeNode* next_brother;
};

其中data表示结点存储的值,first_child指向的是该节点的第一个孩子,next_brother指向的是该节点向右的下一个结点,我们称为兄弟结点。如下图:
在这里插入图片描述

二、二叉树

一棵树中,如果每一个结点的度都不超过2,则称这棵树为二叉树。二叉树中的孩子结点是有左右之分的,位于左边的结点称为左孩子结点,位于右边的结点称为右孩子结点,子树同样也有左右之分,位于左边的称为左子树,位于右边的称为右子树。
在这里插入图片描述

1、特殊的二叉树

(1)满二叉树

如果每一层的结点都达到最大值,则我们称这棵树为满二叉树,如:一棵树中,第一层是根节点,最多只有一个结点,第二层最大有两个结点,第三层最多有四个结点,第四层最多有8个结点,以此类推,第N层最多有2^(N-1)个结点,如下图就是一棵满二叉树。
在这里插入图片描述
在这里插入图片描述

(2)完全二叉树

满二叉树是一种特殊的完全二叉树,完全二叉树的特点是:如果这棵树有N层,前N-1层的结点树都是达到对应层的最大值,最后一层可能达到最大,也可能未达到最大,但是从左到右是满的
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring笔记上(基于XML配置)

新年快乐。 文章目录一、Spring概述1. 为什么要用Spring框架?2. Spring介绍二、IOC/DI快速入门1. IOC控制反转2. DI依赖注入三、Bean的配置1. Bean的基础配置2. Bean的别名配置3. Bean的作用范围配置四、Bean的实例化1. 构造方法方式2. 静态工厂方式3. 实例工厂方式…

Java面试题,JVM相关问题

JVM相关问题一 、JDK、JRE、JVM二、内存管理三、GC如何判断对象可以被回收(这是JVM的基础)一 、JDK、JRE、JVM JDK:Java Development Kit【Java开发工具】,提供给Java开发人员来使用的。JRE:Java Runtime Environment…

Solid Edge 放样使用引导曲线

放样用引导曲线的时候被一个错误提示卡了挺长时间——“选来用作路径或横截面的所有边必须连接在一起”,所以记录一下遇到的问题。基础的操作可以去看帮助文件https://docs.sw.siemens.com/zh-CN/doc/246738425/PL20211001099989437.feature_modeling/feat12c&#…

Sprig框架集成(SSM框架) | Sping+SpringMVC+Mybatis

SSM框架 SSM是spingspringMVCmybatis集成的框架:标准的MVC模式,整个系统划分为表现层,controller层,service层,DAO层四层 Spring(业务层) Spring就像是整个项目中装配bean的大工厂,在…

MySQL server options

介绍 MySQL安装部署时,经常会关注一些参数是否合理。其实这些参数分为两类型。环境中调整的绝大部分是引擎层方面的。服务层参数,就是mysqld服务启动时的参数,如:datadir,port,socket之类的的,…

多重背包问题——单调队列优化

一、多重背包问题 我们在之前的文章中曾经讲解过多重背包问题,当时我们讲解了两种方法,一种方法就是三重循环,这种方法最为朴素好想。但是这种方法的时间复杂度非常高,后来我们想到了二进制优化的方式。那么今天我们将再介绍一种…

Java实习------Java基础2

基础语法基本数据类型 熟悉Java有哪些数据类型定义:Java语言是强类型语言,对于每一种数据都定义了明确的具体的数据类型,在内存中分配了不同大小的内存空间。Java语言提供了八种基本类型。六种数字类型(四个整数型,两个…

18. 循环语句while,for语句的详解

python 中的循环语句只有 for 和 while两种&#xff0c;没有do…while循环&#xff0c;这与c/c是不同的。 1. while循环 (1) 语法格式 while <condition>&#xff1a;...# demo, 使用while循环累加1-100的和。 sum 0 counter 1 while counter < 100:sum counterco…

Java 23种设计模式(4.创建者模式-建造者模式)

代码分析 结构图 代码 public class Product {//产品类,多个部件构成List <String> parts new ArrayList<>();public void Add(String part){parts.add(part);}public void show(){System.out.println("creat parts");for(String part:parts){System…

第十届蓝桥杯省赛 C++ B/C组 - 等差数列

✍个人博客&#xff1a;https://blog.csdn.net/Newin2020?spm1011.2415.3001.5343 &#x1f4da;专栏地址&#xff1a;蓝桥杯题解集合 &#x1f4dd;原题地址&#xff1a;等差数列 &#x1f4e3;专栏定位&#xff1a;为想参加蓝桥杯的小伙伴整理常考算法题解&#xff0c;祝大家…

STL分析(九 适配器)

容器适配器&#xff1a;stack&#xff0c;queue stack和queue内含一个deque 函数适配器 binder2nd绑定第二参数 调用的过程中&#xff0c;算法count_if函数读取了迭代器头尾指针后&#xff0c;读取第三个参数为functor object即仿函数。因此在其参数为bind2nd(less< int&g…

LeetCode220123_140、117. 填充每个节点的下一个右侧节点指针 II

给定一个二叉树struct Node {int val;Node *left;Node *right;Node *next;}填充它的每个 next 指针&#xff0c;让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点&#xff0c;则将 next 指针设置为 NULL。初始状态下&#xff0c;所有 next 指针都被设置为 NULL。进阶…

双指针思想,c语言

问题导入 对一个给定的自然数M&#xff0c;求出所有的连续的自然数段&#xff0c;这些连续的自然数段中的全部数之和为M。 例如&#xff1a;1998 1999 2000 2001 2002 10000&#xff0c;所以从1998到2002的一个自然数段为M 10000的一个解。 输入格式 第一行&#xff0…

JQuery总结(三)

jQuery 事件 on可以同时绑定多个事件&#xff0c;并且动态添加的元素也会自动添加事件 自动触发事件&#xff1a; 案例1&#xff1a; <style>div{width: 100px;height: 200px;background-color: violet;transition: all .5s;}.current{width: 200px;height: 100px;ba…

ARP渗透与攻防(三)之流量分析

ARP攻击-流量分析 ARP渗透与攻防(一)之ARP原理 ARP渗透与攻防(二)之断网攻击 系列文章 1.环境准备 1.kali作为攻击机 2.win10作为靶机 IP地址&#xff1a;192.168.110.11 3.网关 IP地址&#xff1a;192.168.110.1 2.kali数据包转发 出于安全考虑&#xff0c;Linux系统默…

使用Py6S计算瑞利反射率教程

1、前言那么&#xff0c;首先&#xff0c;什么是瑞利反射率&#xff1f; 好吧&#xff0c;这是由大气中的瑞利散射引起的反射率&#xff08;在大气层顶部测量&#xff09;。 这是大气中气体分子对光的波长依赖性散射——这是光穿过大气时不可避免的结果。所以&#xff0c;关于如…

【2022年度总结与2023展望】---22年故事不长,且听我来讲

&#x1f680;write in front&#x1f680; &#x1f4dd;个人主页&#xff1a;认真写博客的夏目浅石. &#x1f4e3;系列专栏&#xff1a;故事 文章目录前言一、高考前及高考后的暑假二、大一上的生活2.1 感受校园美景2.2 进入ACM实验室2.3 比赛和比赛经历三、那些帮助过我的人…

AlmaLinux 9 安装Oracle GraalVM Enterprise Edition 22.3.x

今天我们尝试一下在AlmaLinux 9 安装Oracle GraalVM Enterprise Edition 22.3.x。 GraalVM Enterprise 22是包含新功能的最新版本&#xff0c;但不是Long-Term-Support (LTS) 版本。 注意&#xff1a;下载Oracle GraalVM Enterprise Edition需要有Oracle账户&#xff0c;如果没…

六、pyhon操作mysql篇(黑马程序猿-python学习记录)

黑马程序猿的python学习视频&#xff1a;https://www.bilibili.com/video/BV1qW4y1a7fU/ 目录 1. 下载pymysql 2. 新建数据库 3. mysql服务器版本查询 4. 执行非查询性质的SQL 5. 执行查询性质的sql ​​​​​​​6. 执行新增sql 1. 下载pymysql 右下角点击版本 选择解释器设…

基于Markdown文件的个人wiki

节后第一更&#xff0c;老苏祝您兔年大吉&#xff0c;幸福安康&#xff0c;事事顺心&#xff01; 什么是 wikmd &#xff1f; wikmd 是一个基于文件的 wiki&#xff0c;旨在简化。这些文档完全用 Markdown 编写&#xff0c;使用 pandoc 将 Markdown 文件转换为 html5。 &#…