树与二叉树堆:树
目录
树:
树的概念:
树的相关概念:
1、结点的度:
2、叶节点:度为0的节点
3、非终端节点或分支节点:
4、父节点和子节点:
5、兄弟节点:
6、树的度:
7、树的层次或则结点的层次:
8、堂兄弟节点:
9、祖先节点:
10、子孙节点:
11、森林:
树的结构与递归:
树与非树的判断:
树的实现:
树的实际运用:

树:
树的概念:
树是一种非线性的数据结构,它是由n (n>=0)个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的。
- 有一个特殊的结点,称为根结点,根结点没有前驱结点
- 除根结点外,其余结点被分成M(M>0)个互不相交的集合T1、T2、...... Tm,其中每一个集合Ti(1<= i<=m)又是一棵结构与树类似的子树。每棵子树的根结点有且只有一个前驱,可以有0个或多个后继
- 简单来说,树是一种逻辑和物理上都不连续的数据结构

如图所示,就像是一种树形结构,但是注意!树形结构中,子树之间不能有交集,否则就不是树形结构
树的相关概念:
在树的相关概念中,一般使用树和人类情缘关系的概念进行结合描述。
1、结点的度:
一个结点的子节点个数,这个不包括子结点的子节点!
2、叶节点:度为0的节点
3、非终端节点或分支节点:
度不为0的节点,也因此所以树可以分为,根、叶节点、分支节点
4、父节点和子节点:
一个结点既可以是父亲结点也可以是孩子结点
5、兄弟节点:
同一个父节点的节点之间的相互称呼
6、树的度:
就看那个节点的度最大,那么这个节点的度就是所在树的度
7、树的层次或则结点的层次:
树的高度就是树的最大层次、且树的层次一般从1开始。
8、堂兄弟节点:
各自的父节点是兄弟节点
9、祖先节点:
因为没有单指,所以这个节点这条分支上都可以说是他的祖先节点
10、子孙节点:
子孙节点就是该的子节点衍生出去的节点都可以说苏该节点的子孙
11、森林:
多颗不相关不相交的树就叫森林。
树的结构与递归:

如图所示,一个树一定是由一个根和多颗子树构成的,子树又可以变为一个根和更小的几个子树构成,直到拆解为叶节点,这种就是递归!
树与非树的判断:

以上三者都不是树:
- 子树是不相交的
- 除了根结点外,每个结点有且仅有一个父结点
树的实现:
树结构相对线性表就比较复杂了,要存储表示起来就比较麻烦了,既然保存值域,也要保存结点和结点之间的关系,实际中树有很多种表示方式如:双亲表示法,孩子表示法、孩子双亲表示法以及孩子兄弟表示法等。
我们这里就简单的了解其中最常用的孩子兄弟表示法 ,也就是左兄弟又孩子表示法。
- 左孩子是指 指向左边的第一个孩子,右兄弟是指 指向它右边的第一个兄弟
所以想要找一个节点的所有的子节点(不包括子节点的子节点),可以通过左孩子,然后在用左孩子的右兄弟开始遍历,一直遍历右兄弟,直到空为止
树的实际运用:


相关文章:
树与二叉树堆:树
目录 树: 树的概念: 树的相关概念: 1、结点的度: 2、叶节点:度为0的节点 3、非终端节点或分支节点: 4、父节点和子节点: 5、兄弟节点: 6、树的度: 7、树的层次或…...
【监控系统】日志可视化监控体系ELK搭建
1.ELK架构是什么 ELK是ElasticsearchLogstashKibana的简称。 Elasticsearch是一个开源的分布式搜索和分析引擎,可以用于全文检索、结构化检索和分析,它构建在Lucene搜索引擎库之上,是当前使用较为广泛的开源搜索引擎之一。 Logstash是一个…...
【Linux】22、CPU 评价指标、性能工具、定位瓶颈、优化方法论:应用程序和系统
文章目录 一、评价 CPU 的指标1.1 CPU 使用率1.2 平均负载(Load Average)1.3 上下文切换1.4 CPU 缓存命中率 二、性能工具2.1 维度:从 CPU 性能指标出发,即当你查看某性能指标时,要清除知道哪些工具可以做到2.2 维度&a…...
Foodpanda API连接的艺术:无代码开发如何集成营销系统和广告推广工具
连接Foodpanda和电商平台的无代码开发 Foodpanda不仅是一家提供快速外卖服务的国际品牌,而且其创新的技术解决方案还能帮助电商企业优化系统运营。通过无代码开发的方法,即使没有专业的API开发知识,商家也能实现高效的电商系统和客服系统连接…...
SpringBoot——数据访问
优质博文:IT-BLOG-CN 对于数据访问层,无论是SQL还是NoSQL,SpringBoot默认采用整合Spring Data的方式进行统一处理,添加大量自动配置,屏蔽了很多设置。引入各种xxxTemplate,xxxRepository来简化我们对数据访…...
【C++深度剖析学习总结】28 函数对象分析
1.客户需求 编写一个函数,满足三个需求 函数可以获得斐波那契数列每项的值 每调用一次返回一个值 函数可根据需要重复使用 for(int i =0; i<10; i++) { cout << fib() << endl; } 第一个解决方案 #include<iostream> #include<string> using na…...
持续集成部署-k8s-配置与存储-配置管理:SubPath
持续集成部署-k8s-配置与存储-配置管理:SubPath 1. 简介2. 测试 挂载文件目录3. subPath 解决挂载目录时覆盖原容器内文件夹1. 简介 在Kubernetes (K8s) 中,SubPath是用于指定容器内部目录挂载的一个属性。它可以在Pod中指定某个Volume挂载到容器内部的特定目录下,以便容器…...
git容易出问题的命令
#首先进行git init初始化本地仓库 git init #再进行拉取远程仓库代码 git clone http://以上这种情况建立在第一次拉取仓库的操作 如果你已经拉取过仓库要进行关联的话,就使用这种方法 #关联远程仓库 git remote add origin https:// # 拉取代码 git pull origin/…...
Mongodb命名和文档限制
选用mongodb时,需要了解与mongodb数据大小,命名上的限制。针对这些限制,本文针对这些限制进行翻译整理。 BSON文档 mongodb中的数据记录,按照文档的形式保存。文档保存在一种类似于JSON的BSON结构中。Mongodb对BSON做了一些限制…...
pyQt主界面与子界面切换简易框架
本篇来介绍使用python中是Qt功能包,设置一个简易的多界面切换框架,实现主界面和多个子界面直接的切换显示。 1 主界面 设计的Demo主界面如下,主界面上有两个按钮图标,点击即可切换到对应的功能界面中,进入子界面后&a…...
软考-高级-系统架构设计师教程(清华第2版)【第12章 信息系统架构设计理论与实践(P420~465)-思维导图】
软考-高级-系统架构设计师教程(清华第2版)【第12章 信息系统架构设计理论与实践(P420~465)-思维导图】 课本里章节里所有蓝色字体的思维导图...
【左程云算法全讲11】贪心算法 并查集
系列综述: 💞目的:本系列是个人整理为了秋招面试的,整理期间苛求每个知识点,平衡理解简易度与深入程度。 🥰来源:材料主要源于左程云算法课程进行的,每个知识点的修正和深入主要参考…...
CSS中4种关系选择器
元素(标签)之间的关系 父元素:直接包含子元素的元素 子元素:直接被父元素包含的元素 祖先元素:直接或间接包含后代元素的元素,父元素也是祖先元素 后代元素:直接或间接被祖先元素包含的元素,子元素也是后代…...
蓝牙模块(HC-05)与手机连接,蓝牙与蓝牙互联,电脑通过蓝牙控制单片机
任务一:蓝牙与手机连接 所用模块: HC-05蓝牙模块,USB TO TTL手机APP为SPP蓝牙串口 第一章:蓝牙模块配置 一:HC-05与USB TO TTL连接 EN:为使能引脚,一般不接 VCC:接USB TO TTL模…...
安装 eslint 配置指南 及 遇到的一些问题记录
前端eslint配置指南 背景 当前前端项目风格混乱,每个人有自己的开发习惯,有自己的格式化习惯,不便于项目的风格统一,不利于代码维护有的项目eslint没有用起来,没有起到规范代码的作用,导致出现一些基础代码…...
trzsz支持文件拖动到终端进行上传,类似lrzsz
考虑到 LapTop -> Host 1 -> Host 2 -> Docker -> TMUX,使用scp或sftp命令不方便;使用rz和sz命令就会方便很多,但是却又与 TMUX 不兼容(备注:Tmux是一个终端复用工具,允许用户在一个终端窗口中…...
Doris DDL和DML
1 创建用户和数据库 1)创建test用户 mysql -h hadoop1 -P 9030 -uroot -p create user test identified by test; 2)创建数据库 create database test_db; 3)用户授权...
NewStarCTF2023 Reverse方向Week3 ez_chal WP
分析 题目:ez_chal 一个XTEA加密, V6是key,v5是输入,然后v7就是密文。 看了v6,要用动调。 ELF文件用ida的远程调试。 然后在kali上输入长度为32的flag 全部转换成dd 再提取密文。 EXP #include <stdio.h>…...
程序员如何“升级打怪”?我用了这几个“歪瓜”!
不会吧?不会吧?计算机本命专业出身、以及半路出家的,混了几年了,还在新手村?对得起这几年摸的鱼? 思考一下:如何从小白一跃为大师,从此走上人生巅峰、迎娶白富美?变强只…...
模具制造厂ERP都有哪些牌子?模具制造厂ERP有什么用
模具制造通常会涉及物料领用、成品入库、工艺流转、投入水口、配方、模具、生产啤数统计等众多环节,各个环节数据的实时和准确传递,有利于企业清晰掌握订单生产进度,及时调整制造策略等。 有些模具制造工厂采用传统的管理模式,随…...
天梯赛L3-026传送门:用Splay树模拟‘交换后缀’,保姆级代码逐行解析
天梯赛L3-026传送门:用Splay树模拟‘交换后缀’,保姆级代码逐行解析 在算法竞赛中,数据结构的选择往往决定了解决问题的效率与优雅程度。天梯赛L3-026传送门这道题目,表面上看是一个关于路径操作的模拟题,实则暗藏了对…...
力扣-最后一个单词长度(58)
重点:1.循环初始值:注意不能越界。如果直接取字符串长度则下标会溢出,所以要减1.2.循环条件:注意等于号,i >0,等号不成立的话会遗漏没有空格的情况3.循环中判断条件:考虑字符串最后面为空格的情况。clas…...
在Node.js后端服务中集成Taotoken多模型API的详细步骤
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 在Node.js后端服务中集成Taotoken多模型API的详细步骤 对于Node.js开发者而言,将大模型能力集成到后端服务中已成为构建…...
5分钟搞定华硕笔记本性能控制:G-Helper终极轻量化解决方案
5分钟搞定华硕笔记本性能控制:G-Helper终极轻量化解决方案 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops with nearly the same functionality. Works with ROG Zephyrus, Flow, TUF, Strix, Scar, ProArt, Vivobook, Zenbook…...
NOR Flash技术解析与嵌入式系统应用实践
1. NOR Flash技术基础与嵌入式应用优势NOR Flash作为一种非易失性存储器,自1984年问世以来已成为嵌入式系统的核心存储方案。其核心工作原理基于浮栅晶体管结构,通过在浮栅中注入或释放电荷来实现数据的存储与擦除。与NAND Flash相比,NOR Fla…...
当你的Android设备‘睡不醒’:wakelock机制详解与常见问题排查
当你的Android设备“睡不醒”:wakelock机制详解与常见问题排查 你是否遇到过这样的情况:明明已经锁屏了,但手机电量却消耗得异常快?或者设备在应该休眠的时候依然保持活跃,导致发热和续航缩水?这些问题很可…...
AI世界模型中的一致性三原则解析与应用
1. 项目概述"世界模型中的一致性三原则"这个概念最近在人工智能和认知科学领域引起了广泛讨论。作为一名长期从事机器学习研究的从业者,我一直在思考如何构建更接近人类认知方式的AI系统。这个三原则框架提供了一个极具启发性的视角,它从模态、…...
高速数字与混合信号设计:S参数、PLL与电源完整性实战解析
1. 从DesignCon 2012看高速数字与混合信号设计的核心挑战与实战应对十几年前,当我还是一名刚入行的硬件工程师,面对PCB上GHz级别的信号完整性问题焦头烂额时,DesignCon这样的行业盛会就像一座灯塔。2012年的DesignCon,其技术议题的…...
警惕!AI智能体成企业新“成本黑洞”:隐性成本防坑指南
很多老板谈起“上智能体”,第一反应是:现在大模型调用很便宜,平台也说“低代码、几天上线”,怎么可能是成本黑洞?问题就在这里——显性费用确实越来越低,但隐性消耗,正在悄悄吞掉预算、拖慢团队…...
MotionGPT3:基于大语言模型的文本与3D动作生成技术解析
1. 项目概述:当大语言模型学会“看”动作最近在探索多模态大模型的应用边界时,我深度体验了一个名为“MotionGPT3”的开源项目。这个项目来自OpenMotionLab,它的核心目标非常明确:让大语言模型(LLM)不仅能理…...
















