数据结构:满二叉树 (Full Binary Tree) 和 完全二叉树 (Complete Binary Tree)

目录

重要的术语澄清

完美二叉树 (Perfect Binary Tree)

完全二叉树 (Complete Binary Tree)

大比拼 (Comparison)

相互关系的第一性推导 


我们来深入探讨两种在算法中非常重要的、具有特定“形状”的二叉树:满二叉树 (Full Binary Tree) 和 完全二叉树 (Complete Binary Tree)。

最关键的是,我们会将它们与之前学过的严格二叉树 (Strict Binary Tree) 进行详细的比较。

数据结构:严格二叉树 (Strict Binary Tree)-CSDN博客

这三者之间的区别和联系是常考点,也是一个非常容易混淆的地方,所以这次的第一性推导会特别注重辨析。


重要的术语澄清

在开始之前,我必须先解决一个长期困扰学习者的问题:术语混乱。

  1. Strict Binary Tree (严格二叉树): 我们已经学过,定义非常清晰——每个节点要么有0个孩子,要么有2个孩子。

  2. Full Binary Tree: 这是最混乱的术语。

    • 在很多国际经典教材(如《算法导论》)和学术界中,"Full Binary Tree" 就是我们学的 "Strict Binary Tree"。

    • 但是,在中国国内的很多教材中,“满二叉树” 指的是一种结构最完美的树,即所有叶子都在同一层。为了避免这种语义混淆,我们把这种最完美的树称为 完美二叉树 (Perfect Binary Tree)

  3. Complete Binary Tree (完全二叉树): 这个术语的定义是统一的,没有争议。

为了本次学习的清晰性,我们将采用以下定义:

  • 严格二叉树 (Strict Binary Tree): 度为0或2。

  • 完美二叉树 (Perfect Binary Tree): 国内教材中的“满二叉树”,是一种极致形态。

  • 完全二叉树 (Complete Binary Tree): 为数组表示法而生的结构。


完美二叉树 (Perfect Binary Tree)

让我们从一个问题开始——一棵二叉树最“完美”、最“饱满”、最“对称”的形态应该是什么样的?

推导1 ——饱满:要想“饱满”,内部就不应该有任何浪费的空间。

任何一个非叶子节点,如果只挂了一个孩子,那它的另一个孩子位就空着,这不“饱满”。

所以,所有非叶子节点都必须有两个孩子。(这恰好是严格二叉树的定义)。

推导2 ——对称: 要想“对称”,树的末端应该是整齐划一的。

如果有些叶子在第3层,有些在第4层,那这棵树看起来就像参差不齐的灌木,不够“完美”。

所以,所有的叶子节点必须在同一层

h = 2  (高度 2)●/ \●   ●/ \ / \●  ● ●  ●

将这两个推论合二为一,就得到了完美二叉树 (Perfect Binary Tree) 的定义:

一棵深度为 k 且有 2^(k + 1) − 1 个节点的二叉树。用更直观的语言描述就是:

  1. 它是一棵严格二叉树。

  2. 并且,它所有的叶子节点都在最下面一层。

这棵树的形状像一个完美的等腰三角形,没有任何空缺。

性质:

  • 节点数与高度的关系是固定的:对于高度为 h 的完美二叉树,其节点数 n 永远是它能达到的最大值,不多不少,即 n = 2^(h + 1) − 1。

  • 它是严格二叉树的一种非常特殊的特例。


完全二叉树 (Complete Binary Tree)

完美二叉树的要求太苛刻了。如果我有6个节点,就无法构成一棵完美二叉树(高度为1的完美树有3个节点,高度为2的有7个)。

那么,在节点数不“完美”的情况下,如何让树的形态尽可能地紧凑、不浪费空间呢?

推导1 ——填充顺序: 要想紧凑,我们应该从上到下,一层一层地去填充节点。不能第2层还没满,就去放第3层的节点。

所以,树的所有层,除了最后一层,都必须是满的(即构成一个完美二叉树)。

推导2 ——最后一层的排列: 对于最后一层,节点可能没有填满。那这些节点应该怎么放?是随便放,还是靠右放,还是靠左放?

为了“紧凑”,最自然的方式就是从左到右依次排列,中间不能有空隙。

满二叉树 (高度 2):●/ \●   ●/ \ / \●  ● ●  ●完全二叉树(去掉最右叶子):●/ \●   ●/ \ / ●  ● ●

将这两个推论合二为一,就得到了完全二叉树 (Complete Binary Tree) 的定义:

一棵二叉树,如果它除了最底层之外的其他各层都被完全填满,并且最底层的所有节点都连续地集中在左边,那么它就是一棵完全二叉树。

这个“从上到下,从左到右,连续排列”的特性,使其与数组表示法完美契合!

数据结构:二叉树的表示方式(Representation of Binary Trees)-CSDN博客

当你按层序遍历一个完全二叉树时,得到的节点序列可以不多不少、不留一个空位地(没有-1作为占位符)存入一个数组中。

完全二叉树这个概念,可以说就是为了高效的数组表示法而生的。 这是理解它的关键。


大比拼 (Comparison)

现在我们把三个概念放在一起,从不同维度进行比较。

对比维度严格二叉树 (Strict)完美二叉树 (Perfect)完全二叉树 (Complete)
一句话定义节点度数要么是0,要么是2节点全满,叶子在同一层节点按层序连续排列
允许的节点度只有 0 和 2只有 0 和 2可以是 0, 1, 2<br>(最多只允许有一个度为1的节点)
形状要求无特定形状要求,可高可矮必须是完美的金字塔形必须是“左对齐”的紧凑形状
和别人的关系是一个比较宽泛的分类是严格二叉树的特例<br>是完全二叉树的特例不一定是严格二叉树<br>(当节点总数为偶数时,必有1个度为1的节点)
数组表示法如果很“瘦”,会浪费巨大空间空间利用率100%,没有浪费空间利用率100%,完美适配

相互关系的第一性推导 

我们可以把这些树的集合想象成几个圈:

1. 完美二叉树是标准最严苛的。它既要求所有内部节点度为2(满足严格定义),又要求节点是连续的(满足完全定义)。

所以,完美二叉树的圈是最小的,它同时位于严格树和完全树两个圈的交集之内。

  • 完美 => 严格 (成立)

  • 完美 => 完全 (成立)

完美二叉树: ●/     \●         ●/   \     /   \●     ●   ●     ●/ \   / \ / \   / \●  ●  ●  ● ● ●  ●  ●

2. 严格二叉树只对节点的“度”有要求。它不关心节点是不是“左对齐”。你可以构造一棵严格二叉树,它中间有空位,因此它不是完全二叉树。

  • 严格 => 完全 (不成立)

严格二叉树:●/   \●      ●/   \●     ●/ \   / \●   ● ●   ●

3. 完全二叉树只对节点的“位置”有要求。它不关心节点的“度”。当节点总数是偶数时,必然会产生一个只有一个左孩子的节点,它的度是1,这就不满足严格二叉树的定义。

  • 完全 => 严格 (不成立)

完全二叉树:●/     \●         ●/   \     /   \●     ●   ●     ●/ \   / ●  ●  ●  

结论:

  • 完美二叉树 是最特殊、最规整的,它同时是一棵严格二叉树和一棵完全二叉树。

  • 严格二叉树 和 完全二叉树 是从两个不同维度(“度” vs “位置”)对树进行的约束,它们有交集(交集就是完美二叉树),但谁也不是谁的子集。

理解了这些从基本原则出发的定义和它们之间的逻辑关系,你就再也不会把这几个概念搞混了。

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

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

相关文章

OpenJDK 17的C1和C2编译器实现中,方法返回前插入安全点(Safepoint Poll)的机制

OpenJDK 17 JIT编译器堆栈分析-CSDN博客 在OpenJDK 17的C1和C2编译器实现中&#xff0c;方法返回前插入安全点&#xff08;Safepoint Poll&#xff09;的机制主要涉及以下关键步骤&#xff0c;结合源代码进行分析&#xff1a; 1. 安全点轮询桩&#xff08;Safepoint Poll Stu…

【论文笔记】STORYWRITER: A Multi-Agent Framework for Long Story Generation

论文信息 论文标题&#xff1a;StoryWriter: A Multi-Agent Framework for Long Story Generation 论文作者&#xff1a;Haotian Xia, Hao Peng et al. (Tsinghua University) 论文链接&#xff1a;https://arxiv.org/abs/2506.16445 代码链接&#xff1a;https://github.com/…

Cohere 开发企业级大型语言模型(LLM)

Cohere 是一家专注于开发企业级大型语言模型&#xff08;LLM&#xff09;的公司。该公司推出了一系列名为 “Command” 的模型&#xff0c;其中最强大的 “Command A” 于今年三月首次亮相 Cohere 还提供嵌入模型&#xff0c;这是一种将文件转化为神经网络可以理解的紧凑数值形…

Rust Web框架Axum学习指南之入门初体验

一、准备阶段 确保已经安装 rust&#xff0c;开发环境使用 vscode 或者 rustrover 都可以。接着就可以创建项目&#xff0c;通过编辑器创建或者命令行创建都可以&#xff1a; cargo new axum-admin二、添加依赖 添加依赖如下&#xff1a; [package] name "axum-admin&quo…

autofit.js: 自动调整HTML元素大小的JavaScript库

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》、《前端求职突破计划》 &#x1f35a; 蓝桥云课签约作者、…

RocketMQ 命名服务器(NameServer)详解

&#x1f680; RocketMQ 命名服务器&#xff08;NameServer&#xff09;详解 NameServer 是 RocketMQ 架构中的轻量级路由发现服务&#xff0c;它不参与消息的收发&#xff0c;但承担着整个集群的“地址簿”和“导航系统”的关键角色。 理解 NameServer 的设计与工作原理&#…

代码随想录算法训练营四十三天|图论part01

深度优先搜索&#xff08;dfs&#xff09;理论基础 dfs就是可一个方向去搜直到尽头再换方向&#xff0c;换方向的过程就涉及到了回溯。 代码框架 因为dfs搜索可一个方向&#xff0c;并需要回溯&#xff0c;所以用递归的方式来实现是最方便的。 先来回顾一下回溯法的代码框架…

飞算JavaAI金融风控场景实践:从实时监测到智能决策的全链路安全防护

目录一、金融风控核心场景的技术突破1.1 实时交易风险监测系统1.1.1 高并发交易数据处理1.2 智能反欺诈系统架构1.2.1 多维度欺诈风险识别1.3 动态风控规则引擎1.3.1 风控规则动态管理二、金融风控系统效能升级实践2.1 风控模型迭代加速机制2.1.1 自动化特征工程结语&#xff1…

Vue 组件二次封装透传slots、refs、attrs、listeners

最近写了一个开源项目&#xff0c;有些地方需要二次封装&#xff0c;需要透传一些数据&#xff0c;需要注意的是ref&#xff0c;我这里使用俩种方式间接传递ref&#xff0c;具体如下&#xff1a; 使用&#xff1a; import VideoPlayer from ./index.jsVue.use(VideoPlayer)inde…

介绍大根堆小根堆

文章目录一、核心定义与结构特性示例&#xff08;以“数组存储堆”为例&#xff09;二、堆的两个核心操作1. 插入操作&#xff08;以小根堆为例&#xff09;2. 删除极值操作&#xff08;以小根堆为例&#xff0c;删除根节点的最小值&#xff09;三、小根堆 vs 大根堆&#xff1…

【Html网页模板】赛博朋克数据分析大屏网页

目录专栏导读✨ 项目概述&#x1f3a8; 设计理念&#x1f6e0;️ 技术架构核心技术栈设计模式&#x1f3af; 核心功能1. 视觉效果系统&#x1f308; 色彩体系2. 数据可视化模块&#x1f4ca; 主图表系统&#x1f4c8; 性能监控面板3. 实时数据流系统⚡ 数据流动画&#x1f4ca;…

【经典上穿突破】副图/选股指标,双均线交叉原理,对价格波动反应灵敏,适合捕捉短期启动点

【经典上穿突破】副图/选股指标&#xff0c;双均线交叉原理&#xff0c;对价格波动反应灵敏&#xff0c;适合捕捉短期启动点 这是一款结合短线与中线信号的趋势跟踪指标&#xff0c;通过双均线交叉原理捕捉股价突破时机&#xff0c;适用于个股分析和盘中选股。 核心功能模块&…

RK3568 NPU RKNN(四):RKNN-ToolKit2性能和内存评估

文章目录1、前言2、目标3、完整的测试程序4、运行测试程序5、程序拆解6、总结1、前言 本文仅记录本人学习过程&#xff0c;不具备教学指导意义。 2、目标 使用野火提供的示例程序&#xff0c;体验 RKNN-ToolKit2 在PC端使用连板推理&#xff0c;进行性能和内存评估。 3、完…

ASP.NET 上传文件安全检测方案

一、前端初步过滤&#xff08;防误操作&#xff09;<!-- HTML部分 --><input type"file" id"fileUpload" accept".jpg,.png,.pdf,.docx" /><button onclick"validateFile()">上传</button><script>func…

Nacos Server 3.0.x安装教程

前言 注&#xff1a; 1.Nacos Server 3.0.x 要求 JDK版本不低于17。 2.Nacos 2.2.0 及以上版本需要 Java 11 或更高版本。 3.Java 8&#xff0c;需要下载 Nacos 2.1.x 及以下版本 JDK17安装 JDK官方下载地址&#xff1a;Oracle官网JDK下载地址 JDK17&#xff1a;JDK17下载地…

【数据库干货】六大范式速记

1NF、2NF、3NF、BCNF、4NF、5NF都是数据库设计中的范式&#xff08;Normalization&#xff09;&#xff0c;用于确保数据库中的数据结构尽可能地减少冗余&#xff0c;避免更新异常、插入异常、删除异常等问题&#xff0c;从而提高数据的存储效率和一致性。 本篇文章简单讲解下各…

Java开发主流框架搭配详解及学习路线指南

文章目录一、前言&#x1f517;二、主流Java框架搭配2.1 Spring Boot MyBatis-Plus Spring Cloud2.2 Spring Boot Spring Data JPA Spring Cloud2.3 Quarkus/Vert.x (响应式编程栈)三、技术选型建议四、Java学习路线指南阶段1&#xff1a;Java基础 (4-6周)阶段2&#xff1a…

flutter-使用device_info_plus获取手机设备信息完整指南

文章目录1. 概述2. 安装与配置3. 基本使用方法3.1. 创建实例3.2. 区分平台获取信息4. 详细信息获取4.1. Android 设备信息4.2. iOS 设备信息4.3. Web 浏览器信息4.4. Windows 设备信息5. 实战示例6. 注意事项6.1. 权限问题6.2. 隐私保护6.3. 平台差异处理6.4. 性能考虑7. 常见问…

Java 时间处理 API 全解析:从 JDK7 到 JDK8 的演进

个人主页-爱因斯晨 友友们&#xff0c;互三咯~ 目录 个人主页-爱因斯晨 ​编辑 前言 一、JDK7 时间处理基石 ——Date 类 &#xff08;一&#xff09;Date 类基本功能 &#xff08;二&#xff09;Date 类的局限性 二、格式化时间好帮手 ——SimpleDateFormat 类 &#…

duiLib 实现鼠标拖动标题栏时,窗口跟着拖动

1、布局文件&#xff0c;窗口需设置可拖动的标题栏区域&#xff1a;2、HandleMessage函数中&#xff0c;处理WM_LBUTTONDOWN消息&#xff0c;判断鼠标在标题栏&#xff0c;让系统处理窗口移动。代码片段如下&#xff1a;else if (uMsg WM_LBUTTONDOWN) {// 获取鼠标点击坐标PO…