当前位置: 首页 > news >正文

树与二叉树堆:树

目录

树:

树的概念:

 树的相关概念:

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. 除了根结点外,每个结点有且仅有一个父结点  

树的实现: 

树结构相对线性表就比较复杂了,要存储表示起来就比较麻烦了,既然保存值域,也要保存结点和结点之间的关系,实际中树有很多种表示方式如:双亲表示法,孩子表示法、孩子双亲表示法以及孩子兄弟表示法等。

我们这里就简单的了解其中最常用的孩子兄弟表示法 ,也就是左兄弟又孩子表示法。

  • 左孩子是指 指向左边的第一个孩子,右兄弟是指 指向它右边的第一个兄弟 

                                   

所以想要找一个节点的所有的子节点(不包括子节点的子节点),可以通过左孩子,然后在用左孩子的右兄弟开始遍历,一直遍历右兄弟,直到空为止

树的实际运用:  


相关文章:

树与二叉树堆:树

目录 树&#xff1a; 树的概念&#xff1a; 树的相关概念&#xff1a; 1、结点的度&#xff1a; 2、叶节点&#xff1a;度为0的节点 3、非终端节点或分支节点&#xff1a; 4、父节点和子节点&#xff1a; 5、兄弟节点&#xff1a; 6、树的度&#xff1a; 7、树的层次或…...

【监控系统】日志可视化监控体系ELK搭建

1.ELK架构是什么 ELK是ElasticsearchLogstashKibana的简称。 Elasticsearch是一个开源的分布式搜索和分析引擎&#xff0c;可以用于全文检索、结构化检索和分析&#xff0c;它构建在Lucene搜索引擎库之上&#xff0c;是当前使用较为广泛的开源搜索引擎之一。 Logstash是一个…...

【Linux】22、CPU 评价指标、性能工具、定位瓶颈、优化方法论:应用程序和系统

文章目录 一、评价 CPU 的指标1.1 CPU 使用率1.2 平均负载&#xff08;Load Average&#xff09;1.3 上下文切换1.4 CPU 缓存命中率 二、性能工具2.1 维度&#xff1a;从 CPU 性能指标出发&#xff0c;即当你查看某性能指标时&#xff0c;要清除知道哪些工具可以做到2.2 维度&a…...

Foodpanda API连接的艺术:无代码开发如何集成营销系统和广告推广工具

连接Foodpanda和电商平台的无代码开发 Foodpanda不仅是一家提供快速外卖服务的国际品牌&#xff0c;而且其创新的技术解决方案还能帮助电商企业优化系统运营。通过无代码开发的方法&#xff0c;即使没有专业的API开发知识&#xff0c;商家也能实现高效的电商系统和客服系统连接…...

SpringBoot——数据访问

优质博文&#xff1a;IT-BLOG-CN 对于数据访问层&#xff0c;无论是SQL还是NoSQL&#xff0c;SpringBoot默认采用整合Spring Data的方式进行统一处理&#xff0c;添加大量自动配置&#xff0c;屏蔽了很多设置。引入各种xxxTemplate&#xff0c;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://以上这种情况建立在第一次拉取仓库的操作 如果你已经拉取过仓库要进行关联的话&#xff0c;就使用这种方法 #关联远程仓库 git remote add origin https:// # 拉取代码 git pull origin/…...

Mongodb命名和文档限制

选用mongodb时&#xff0c;需要了解与mongodb数据大小&#xff0c;命名上的限制。针对这些限制&#xff0c;本文针对这些限制进行翻译整理。 BSON文档 mongodb中的数据记录&#xff0c;按照文档的形式保存。文档保存在一种类似于JSON的BSON结构中。Mongodb对BSON做了一些限制…...

pyQt主界面与子界面切换简易框架

本篇来介绍使用python中是Qt功能包&#xff0c;设置一个简易的多界面切换框架&#xff0c;实现主界面和多个子界面直接的切换显示。 1 主界面 设计的Demo主界面如下&#xff0c;主界面上有两个按钮图标&#xff0c;点击即可切换到对应的功能界面中&#xff0c;进入子界面后&a…...

​软考-高级-系统架构设计师教程(清华第2版)【第12章 信息系统架构设计理论与实践(P420~465)-思维导图】​

软考-高级-系统架构设计师教程&#xff08;清华第2版&#xff09;【第12章 信息系统架构设计理论与实践&#xff08;P420~465&#xff09;-思维导图】 课本里章节里所有蓝色字体的思维导图...

【左程云算法全讲11】贪心算法 并查集

系列综述&#xff1a; &#x1f49e;目的&#xff1a;本系列是个人整理为了秋招面试的&#xff0c;整理期间苛求每个知识点&#xff0c;平衡理解简易度与深入程度。 &#x1f970;来源&#xff1a;材料主要源于左程云算法课程进行的&#xff0c;每个知识点的修正和深入主要参考…...

CSS中4种关系选择器

元素(标签)之间的关系 父元素&#xff1a;直接包含子元素的元素 子元素&#xff1a;直接被父元素包含的元素 祖先元素&#xff1a;直接或间接包含后代元素的元素&#xff0c;父元素也是祖先元素 后代元素&#xff1a;直接或间接被祖先元素包含的元素&#xff0c;子元素也是后代…...

蓝牙模块(HC-05)与手机连接,蓝牙与蓝牙互联,电脑通过蓝牙控制单片机

任务一&#xff1a;蓝牙与手机连接 所用模块&#xff1a; HC-05蓝牙模块&#xff0c;USB TO TTL手机APP为SPP蓝牙串口 第一章&#xff1a;蓝牙模块配置 一&#xff1a;HC-05与USB TO TTL连接 EN&#xff1a;为使能引脚&#xff0c;一般不接 VCC&#xff1a;接USB TO TTL模…...

安装 eslint 配置指南 及 遇到的一些问题记录

前端eslint配置指南 背景 当前前端项目风格混乱&#xff0c;每个人有自己的开发习惯&#xff0c;有自己的格式化习惯&#xff0c;不便于项目的风格统一&#xff0c;不利于代码维护有的项目eslint没有用起来&#xff0c;没有起到规范代码的作用&#xff0c;导致出现一些基础代码…...

trzsz支持文件拖动到终端进行上传,类似lrzsz

考虑到 LapTop -> Host 1 -> Host 2 -> Docker -> TMUX&#xff0c;使用scp或sftp命令不方便&#xff1b;使用rz和sz命令就会方便很多&#xff0c;但是却又与 TMUX 不兼容&#xff08;备注&#xff1a;Tmux是一个终端复用工具&#xff0c;允许用户在一个终端窗口中…...

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

分析 题目&#xff1a;ez_chal 一个XTEA加密&#xff0c; V6是key&#xff0c;v5是输入&#xff0c;然后v7就是密文。 看了v6&#xff0c;要用动调。 ELF文件用ida的远程调试。 然后在kali上输入长度为32的flag 全部转换成dd 再提取密文。 EXP #include <stdio.h>…...

程序员如何“升级打怪”?我用了这几个“歪瓜”!

不会吧&#xff1f;不会吧&#xff1f;计算机本命专业出身、以及半路出家的&#xff0c;混了几年了&#xff0c;还在新手村&#xff1f;对得起这几年摸的鱼&#xff1f; 思考一下&#xff1a;如何从小白一跃为大师&#xff0c;从此走上人生巅峰、迎娶白富美&#xff1f;变强只…...

模具制造厂ERP都有哪些牌子?模具制造厂ERP有什么用

模具制造通常会涉及物料领用、成品入库、工艺流转、投入水口、配方、模具、生产啤数统计等众多环节&#xff0c;各个环节数据的实时和准确传递&#xff0c;有利于企业清晰掌握订单生产进度&#xff0c;及时调整制造策略等。 有些模具制造工厂采用传统的管理模式&#xff0c;随…...

天梯赛L3-026传送门:用Splay树模拟‘交换后缀’,保姆级代码逐行解析

天梯赛L3-026传送门&#xff1a;用Splay树模拟‘交换后缀’&#xff0c;保姆级代码逐行解析 在算法竞赛中&#xff0c;数据结构的选择往往决定了解决问题的效率与优雅程度。天梯赛L3-026传送门这道题目&#xff0c;表面上看是一个关于路径操作的模拟题&#xff0c;实则暗藏了对…...

力扣-最后一个单词长度(58)

重点&#xff1a;1.循环初始值&#xff1a;注意不能越界。如果直接取字符串长度则下标会溢出&#xff0c;所以要减1.2.循环条件&#xff1a;注意等于号&#xff0c;i >0,等号不成立的话会遗漏没有空格的情况3.循环中判断条件&#xff1a;考虑字符串最后面为空格的情况。clas…...

在Node.js后端服务中集成Taotoken多模型API的详细步骤

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 在Node.js后端服务中集成Taotoken多模型API的详细步骤 对于Node.js开发者而言&#xff0c;将大模型能力集成到后端服务中已成为构建…...

5分钟搞定华硕笔记本性能控制:G-Helper终极轻量化解决方案

5分钟搞定华硕笔记本性能控制&#xff1a;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作为一种非易失性存储器&#xff0c;自1984年问世以来已成为嵌入式系统的核心存储方案。其核心工作原理基于浮栅晶体管结构&#xff0c;通过在浮栅中注入或释放电荷来实现数据的存储与擦除。与NAND Flash相比&#xff0c;NOR Fla…...

当你的Android设备‘睡不醒’:wakelock机制详解与常见问题排查

当你的Android设备“睡不醒”&#xff1a;wakelock机制详解与常见问题排查 你是否遇到过这样的情况&#xff1a;明明已经锁屏了&#xff0c;但手机电量却消耗得异常快&#xff1f;或者设备在应该休眠的时候依然保持活跃&#xff0c;导致发热和续航缩水&#xff1f;这些问题很可…...

AI世界模型中的一致性三原则解析与应用

1. 项目概述"世界模型中的一致性三原则"这个概念最近在人工智能和认知科学领域引起了广泛讨论。作为一名长期从事机器学习研究的从业者&#xff0c;我一直在思考如何构建更接近人类认知方式的AI系统。这个三原则框架提供了一个极具启发性的视角&#xff0c;它从模态、…...

高速数字与混合信号设计:S参数、PLL与电源完整性实战解析

1. 从DesignCon 2012看高速数字与混合信号设计的核心挑战与实战应对十几年前&#xff0c;当我还是一名刚入行的硬件工程师&#xff0c;面对PCB上GHz级别的信号完整性问题焦头烂额时&#xff0c;DesignCon这样的行业盛会就像一座灯塔。2012年的DesignCon&#xff0c;其技术议题的…...

警惕!AI智能体成企业新“成本黑洞”:隐性成本防坑指南

很多老板谈起“上智能体”&#xff0c;第一反应是&#xff1a;现在大模型调用很便宜&#xff0c;平台也说“低代码、几天上线”&#xff0c;怎么可能是成本黑洞&#xff1f;问题就在这里——显性费用确实越来越低&#xff0c;但隐性消耗&#xff0c;正在悄悄吞掉预算、拖慢团队…...

MotionGPT3:基于大语言模型的文本与3D动作生成技术解析

1. 项目概述&#xff1a;当大语言模型学会“看”动作最近在探索多模态大模型的应用边界时&#xff0c;我深度体验了一个名为“MotionGPT3”的开源项目。这个项目来自OpenMotionLab&#xff0c;它的核心目标非常明确&#xff1a;让大语言模型&#xff08;LLM&#xff09;不仅能理…...