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

数据结构基础------初识二叉树

数据结构-------二叉树1.树的概念树是一种非线性的数据结构它是由n(n0)个有限结点组成一个具有层次关系的集合。我们把它叫做树是因为它看起来像一颗倒挂的树也就是根朝上叶在下。特点:1.有一个特殊的结点称为根结点根结点没有前驱节点。2.除根结点外其余结点被分成M(M0)个互不相交的集合T1、T2、…、Tm,其中每一个集合Ti(1im)又是一棵与数类似的子树。每棵子树的根结点有且只有一个前驱可以有0个或多个后继。因此数是递归定义的。注:在树形结构中子树之间不能有交集否则就不是树形结构。那么我们如何判断什么样的结构不是树形结构呢子树是不相交的(如果存在相交就是图了)除了根节点外每个结点有且只有一个父结点一棵N结点的数有N-1条边如图所示:以上为非树形结构接下来我们来了解一下数的相关术语**父结点/双亲结点**若一个结点含有子结点则这个结点称为其子结点的父结点如上图A是B的父结点**子结点/孩子结点**一个结点含有的子树的根结点称为该结点的子结点如上图B是A的孩子结点结点的度一个结点有几个孩子他的度就是多少比如A的度为6F的度为2K的度为0树的度一棵树中最大的结点的度称为树的度如上图树的度为6叶子结点/终端结点度为0的结点称为叶结点如上图B、C、H、I…等结点为叶结点分支结点/非终端结点:度不为0的结点如上图D、E、F、G…等结点为分支结点兄弟结点具有相同父结点的结点互称为兄弟结点(亲兄弟)如上图B、C是兄弟结点结点的层次从根开始定义起根为第1层根的子结点为第2层以此类推树的高度或深度树中结点的最大层次如上图树的高度为4结点的祖先从根到该结点所经分支上的所有结点如上图A是所有结点的祖先路径一条从树中任意节点出发沿父节点-子节点连接达到任意节点的序列比如A到Q的路径为A-E-J-QH到Q的路径H-D-A-E-J-Q子孙以某结点为根的子树中任一结点都称为该结点的子孙。如上图所有结点都是A的子孙森林由mm0棵互不相交的树的集合称为森林1.2树的表示树结构相对线性表来说比较复杂要存储表示起来就比较麻烦既要保持值域也要保存结点和结点之间的关系实际中树有很多种表示方法如**:双亲表示法孩子表示法、孩子双亲表示法以及孩子兄弟表示法等。在这里就简单了解其中最常用的孩子兄弟表示法**。structTreeNode{structNode*child;//左边开始的第一个孩子结点structNode*brother;//指向其右边的下一个兄弟结点intdata;//结点中的数据域}其表示方法如下图:1.3树形结构的实际运用场景文件系统是计算机存储和管理文件的一种方式它**利用树形结构来组织和管理文件和文件夹。**在文件系统中树结构被广泛应用它通过父结点和子结点之间的关系来表示不同层级的文件和文件夹之间的关联。2.二叉树2.1概念与结构在树形结构中我们最常用的就是二叉树一棵二叉树是结点的一个有限集合该集合由一个根节点加上两块别称为左子树和右子树的二叉树组成或为空。如图:二叉树有以下特点:二叉树不存在度大于2的结点二叉树的子树有左右之分次序不能颠倒因此二叉树是有序树。2.2特殊的二叉树在二叉树中我们又有一些特殊的二叉树一个是满二叉树一个是完全二叉树。2.2.1满二叉树一个二叉树如果每一个层的结点数都达到最大值则这个二叉树就是满二叉树。也就是说如果一个二叉树的层数为k且结点总数是(2^k)-1,则为满二叉树。2.2.2完全二叉树完全二叉树是效率很高的数据结构完全二叉树是由满二叉树而引出来的。对于深度为 K 的有 n 个结点的二叉树当且仅当其每一个结点都与深度为K的满二叉树中编号从 1 至 n 的结点一一对应时称之为完全二叉树。要注意的是满二叉树是一种特殊的完全二叉树。完全二叉树具有以下特点:除了最后一层每层结点个数达到最大最后一层结点个数不一定达到最大(达到最大则为满二叉树也可以为完全二叉树)结点从左到右依次排序(最后一层如果是右结点则不是完全二叉树)以下为它们的关系图二叉树性质根据满二叉树的特点可知若规定根结点的层数为 1 则一棵非空二叉树的第i层上最多有 **2^{i-1}**个结点若规定根结点的层数为 1 则深度为 h 的二叉树的最大结点数是2^{h} - 1若规定根结点的层数为 1 具有 n 个结点的满二叉树的深度 h log₂(n 1)log 以2为底 n1 为对数2.3二叉树的存储结构二叉树一般可以使用两种结构存储一种是顺序结构一种是链式结构。2.3.1顺序结构顺序结构存储就是使用数组来存储一般使用数组只适合表示完全二叉树因为不是完全二叉树会有空间的浪费完全二叉树更适合使用顺序结构存储。现实中我们通常把堆一种二叉树使用顺序结构的数组来存储需要注意的是这里的堆和操作系统虚拟进程地址空间中的堆是两回事一个是数据结构一个是操作系统中管理内存的一块区域分段。2.3.2链式结构二叉树的链式结构是指用链表来表示二叉树通常的方法是链表中每个结点由三个域组成即数据域和左右指针域左右指针分别指向该节点的左右孩子所在的链结点的地址。以上就是二叉树的基本概念这里我们先基础了解一下什么是二叉树在后续如何实现二叉树我会再出一篇博客去介绍如何实现二叉树

相关文章:

数据结构基础------初识二叉树

数据结构-------二叉树 1.树的概念 树是一种非线性的数据结构,它是由n(n>0)个有限结点组成一个具有层次关系的集合。我们把它叫做树是因为它看起来像一颗倒挂的树,也就是根朝上,叶在下。 特点: 1.有一个特殊的结点,称为根结…...

Java 25虚拟线程资源调度黄金参数表(2024 Q3压测实录:TPS提升3.8倍,P99延迟下降67ms)

更多请点击: https://intelliparadigm.com 第一章:Java 25虚拟线程资源调度优化全景概览 Java 25 正式将虚拟线程(Virtual Threads)从预览特性转为标准特性,并深度重构了ForkJoinPool与ThreadScheduler协同机制&#…...

别再用老方法了!用Python+OpenCV搞定Kinect V2相机标定的保姆级避坑指南

Kinect V2相机标定实战:PythonOpenCV避坑全攻略 刚拿到二手Kinect V2的开发者常会遇到各种环境配置和标定问题。市面上许多教程要么依赖过时的库版本,要么省略关键步骤,导致新手在标定过程中频频踩坑。本文将用最新工具链带你完整走通从环境配…...

【Docker WASM边缘部署终极指南】:20年架构师亲授5大高频报错根因与秒级修复方案

更多请点击: https://intelliparadigm.com 第一章:Docker WASM边缘部署全景认知与技术栈演进 WebAssembly(WASM)正从浏览器沙箱走向云原生边缘场景,而 Docker 官方对 WASM 运行时的原生支持(自 Docker Des…...

告别显存焦虑:用bitsandbytes的8位优化器,让你的RTX 3060也能跑大模型(保姆级配置)

用8位优化器释放RTX 3060潜力:低成本玩转LLaMA-7B全攻略 当你在Colab上看到"CUDA out of memory"的红色警告时,是否想过自己的RTX 3060其实也能跑动70亿参数的大模型?2023年柏林工业大学发布的实验数据显示,通过8位量化…...

第6篇:Java面向对象进阶:继承、重写与多态,解锁代码复用新姿势

上一篇我们掌握了Java面向对象基础,学会了定义类、创建对象,用封装保护数据安全,用构造方法简化对象初始化,完成了面向对象版的学生成绩管理案例。但在实际开发中,我们会遇到“多个类拥有相同属性和方法”的场景——比…...

K8s Pod 调度策略与优先级算法优化

Kubernetes作为容器编排领域的标杆,其Pod调度策略与优先级算法的优化直接影响集群资源利用率与应用稳定性。随着企业微服务规模扩大,如何让调度器更智能地平衡节点负载、保障关键业务,成为运维团队的核心挑战。本文将深入剖析调度优化关键技术…...

论文阅读:ICLR 2026 AlphaSteer: Learning Refusal Steering with Principled Null-Space Constraint

总目录 大模型安全研究论文整理 2026年版:https://blog.csdn.net/WhiffeYF/article/details/159047894 https://openreview.net/forum?id1vvbzAqdTe ![ ICLR 2026 | 零空间安全操控 📄 论文背景与基本信息 《AlphaSteer: Learning Refusal Steering…...

C 表达式中的汇编指令

asm 为 gcc 中的关键字,asm 表达式为在 C代码中嵌套汇编指令,该表达式只是单纯的替换出汇编代码,并不对汇编代码的含义进行解析。 asm 表达式有两种形式,第二种 asm-qualifiers 包含了 goto 语句。 第一种形式为常见的用法&#…...

如何永久免费使用IDM:开源激活脚本完整指南

如何永久免费使用IDM:开源激活脚本完整指南 【免费下载链接】IDM-Activation-Script IDM Activation & Trail Reset Script 项目地址: https://gitcode.com/gh_mirrors/id/IDM-Activation-Script 还在为Internet Download Manager(IDM&#x…...

关于C++11的统一初始化语法示例详解

前言本文主要给大家介绍了C11统一初始化语法的相关内容,关于在当前新标准C11的语法看来,变量合法的初始化器有如下形式:1234X a1 {v};X a2 {v};X a3 v;X a4(v);其实,上面第一种和第二种初始化方式在本质上没有任何差别&#xff…...

Win11Debloat:免费Windows系统优化工具终极指南,轻松提升44%性能

Win11Debloat:免费Windows系统优化工具终极指南,轻松提升44%性能 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other change…...

云端还是本地?哪种RFID固定资产系统更合适你的企业?

在数字化转型的浪潮中,越来越多的企业认识到RFID固定资产管理系统的重要性。但当真正准备引进系统时,一个关键却绕不开的问题便摆在面前:到底该选云端还是本地部署?这不仅仅是技术路线的选择题,更关乎企业的成本结构、…...

Ostrakon-VL-8B数据预处理详解:餐饮图像清洗与标注规范

Ostrakon-VL-8B数据预处理详解:餐饮图像清洗与标注规范 如果你正在尝试训练或微调像Ostrakon-VL-8B这样的视觉语言模型,来让它更好地理解餐饮场景,那你肯定知道,数据质量是决定成败的关键。模型再强大,如果喂给它的是…...

推荐2款无需安装实用软件,桌面图标整理设置,简真是Windows神器!

聊一聊今天给大家推荐2款桌面美化小工具。为什么觉得要推荐这个小工具呢?因为最近帮一些人远程处理一些问题。感觉那电脑桌面,密密麻麻,全是小图标。我想找个东西都难,是太难了。我真恨不得上手整理。但又怕整理了,人家…...

mini-job极简分布式延迟任务队列 — 基于 Redis,支持 Cron 周期任务、异步协程和多执行器

mini-job 极简分布式延迟任务队列 — 基于 Redis,支持 Cron 周期任务、异步协程和多执行器。 特性特性说明延迟任务设定延迟秒数,到期自动执行Cron 周期调度支持标准 cron 表达式(分 时 日 月 星期)三种执行器async 协程&#xff…...

内网IP如何申请SSL证书?

一、为什么需要内网IP证书? 很多企业有一个误区:认为“只有域名才能做HTTPS”,或者“内网用HTTP没关系”。现实恰恰相反: 合规硬指标:《数据安全法》等法规明确要求数据传输必须加密,内网明文传输在等保测…...

FastAPI + PostgreSL 实战:给应用装上“缓存”和“日志”翅膀

1. 哑铃图是什么? 哑铃图(Dumbbell Plot),有时也称为DNA图或杠铃图,是一种用于比较两个相关数据点的可视化图表。 它源于人们对更有效数据比较方式的持续探索。 在传统的时间序列比较中,我们通常使用两条折…...

PMC Organometallix宣布所有产品提价

鉴于市场环境发生重大变化,PMC Organometallix, Inc. 宣布,自2026年5月1日起(或根据合同条款允许的时间),全球所有产品线的价格将上调10%至25%。此次调整源于关键投入成本的持续压力,包括原材料成本上涨以及…...

网络安全渗透测试入门|无线安全渗透与防御完整教程

前言 这是给粉丝盆友们整理的网络安全渗透测试入门阶段无线安全渗透与防御教程 喜欢的朋友们,记得给我点赞支持和收藏一下,关注我,学习黑客技术。 1.Aircrack-ng简介 Aircrack- NG是一个完整的工具来评估Wi-Fi网络安全套件。 捕获&#x…...

告别Swagger默认丑界面!.NET Core 6项目集成Knife4jUI保姆级教程

.NET Core 6项目集成Knife4jUI:打造专业级API文档体验 在当今快节奏的开发环境中,API文档的质量直接影响着团队协作效率。许多.NET Core开发者虽然已经使用Swagger生成基础文档,却常常面临界面简陋、功能单一的问题。Knife4jUI作为Swagger UI…...

Qt项目拆分之术:如何用SUBDIRS把大工程拆成小模块(从app到lib的实战)

Qt项目模块化实战:用SUBDIRS构建可扩展工程架构 当你的Qt项目从几百行代码膨胀到数万行时,编译时间开始以分钟计算,团队协作频繁出现文件冲突,新成员面对庞杂的目录结构不知所措——这就是我们需要模块化拆分的临界点。上周我接手…...

5分钟搭建家庭电视直播系统:Kodi IPTV Simple完全指南

5分钟搭建家庭电视直播系统:Kodi IPTV Simple完全指南 【免费下载链接】pvr.iptvsimple IPTV Simple client for Kodi PVR 项目地址: https://gitcode.com/gh_mirrors/pv/pvr.iptvsimple 还在为电视直播体验烦恼吗?想用最简单的方式把网络直播源整…...

Python程序打包为EXE

PowerShell 用anaconda创建虚拟环境 conda -n create XXXconda initconda activate xxx进入要打包的文件夹中安装依赖pip install -r requirements.txt 打包pyinstaller -F -w main.py --clean --noconfirm...

软件产品负责人管理中的需求决策者

在软件开发领域,产品负责人(Product Owner)是决定产品成败的关键角色之一,而需求决策者则是这一角色的核心职能。他们不仅需要理解市场和用户需求,还要在资源有限的情况下,权衡优先级,确保团队交…...

【基于 macOS 虚拟机的 iMessage 批量消息处理技术实践】

一、研究背景与技术意义iMessage 作为苹果生态内置的原生通讯服务,依托系统底层优势,具备端到端加密、无运营商拦截、原生展示等特性,常用于企业内部事务提醒、授权用户服务告知等合规场景。在技术研究过程中,手动单条发送消息效率…...

从ArrayList到VectorSpecies:Java向量化开发全流程拆解,含GraalVM AOT+Linux perf火焰图调优实战

更多请点击: https://intelliparadigm.com 第一章:Java 25 向量 API 硬件加速概览 Java 25 正式将 jdk.incubator.vector 模块升级为标准 API(java.util.vector),标志着 JVM 首次原生支持跨平台向量化计算&#xff0c…...

Live Avatar数字人模型保姆级部署教程:4步搞定AI视频生成

Live Avatar数字人模型保姆级部署教程:4步搞定AI视频生成 1. 准备工作:硬件与软件环境检查 1.1 硬件要求详解 Live Avatar对硬件有明确要求,这是确保模型正常运行的基础: 显卡要求: 最低配置:单卡NVIDIA…...

如何提升域名价值——评估标准

关于Dynadot Dynadot是通过ICANN认证的域名注册商,自2002年成立以来,服务于全球108个国家和地区的客户,为数以万计的客户提供简洁,优惠,安全的域名注册以及管理服务。 Dynadot平台操作教程索引(包括域名邮…...

深度对比:瑞芯微RK3588边缘盒子 vs 其他方案,在智慧油站车牌识别场景下的真实表现

智慧油站车牌识别实战:RK3588边缘计算盒子的性能突围战 当加油站开始拥抱智能化转型,车牌识别系统便成了连接物理世界与数字服务的"第一道闸机"。在华北某连锁油站的改造案例中,技术团队曾面临这样的困境:传统工控机处理…...