【数据结构初阶】二叉树与堆(一)

news2024/9/23 11:19:37

文章目录

  • 一、树的基础概念
    • 1、节点与度数
    • 2、树的度与高度
    • 3、引入:数组下标为何从0开始
    • 4、祖先节点
    • 5、树是递归定义的
    • 6、树与非树的区别
    • 7、代码表示
  • 二、二叉树
    • 2.1、满二叉树
    • 2.2、完全二叉树
    • 2.3、完全二叉树的存储
  • 三、堆

一、树的基础概念

1、节点与度数

节点分为叶节点与分支节点

  • 度数:其子节点的个数
  • 叶节点:无子节点,即节点度数为0
  • 分支节点:度数不为0的节点

2、树的度与高度

  • 树的度:节点中度数最大的度数为树的度
  • 树的高度(深度):树的最大层次
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bg1ltLM8-1722609222670)(https://i-blog.csdnimg.cn/direct/1e7c57da3e6c473e9ee335e7e7056995.png)]

3、引入:数组下标为何从0开始

答:迫于无奈,方便计算。
已知:数组名=数组首元素的地址
且 a[i] = *( a+i )
若下标从1开始,那么首元素 = *( a+1 )该式显然不成立。

4、祖先节点

从我这个节点往上这条路径的节点均为我的祖先节点。

在这里插入图片描述

5、树是递归定义的

一个树可分为根和子树(度>=0)。
在这里插入图片描述

在这里插入图片描述

6、树与非树的区别

树:

  1. 子树间不相交
  2. 除根节点外,每个节点有且仅有一个母(父)节点

非树:子树间相交。

7、代码表示

存储方法:左孩子右兄弟模型(链表)

struct TreeNode
{
	int val;
	struct TreeNode* LeftChild;
	struct TreeNode* RightSister;
};

在这里插入图片描述

二、二叉树

1、定义:树的每个节点的度数最大为2
2、代码模型:左孩子右孩子(可参考左孩子右兄弟模型)

2.1、满二叉树

1、定义:每一层都是满的(2个节点),叶子只在最后一层。
2、第 k 层有 2^(k-1)个节点
总节点个数:2^k - 1
在这里插入图片描述

2.2、完全二叉树

1、定义:设二叉树的高度为k,其前k-1层都是满的,最后一层不满且从左到右必须是连续的。
2、满二叉树是特殊的完全二叉树。
在这里插入图片描述

2.3、完全二叉树的存储

物理结构:在内存中以数组的形式存储。
在这里插入图片描述

原理:在内存中存储以数组的形式,已知一个父节点,则它的后两个数据一定是它的子节点。

  • 1、局限
    只适用于完全/满二叉树,对非完全也可以,但存在很大的空间浪费。

  • 2、优点
    便于访问母(父)子关系
    已知父节点下标为 i
    则 左孩子下标为 2 * i+1, 右孩子下标为 2*i+2

    已知一个子节点的下标为 j
    1、j 为奇数时,为左孩子,父下标为 (j -1)/2
    2、j 为偶数时,为右孩子,父下标为 (j -2)/2
    但在C语言中,除后取整
    故可直接写为 (j -1)/2

三、堆

注:
1、堆是一个完全二叉树(可用数组存储)
2、C语言中的堆、栈是内存的划分,与数据结构中的堆(二叉树)、栈(后进先出)不一样

大堆:任何一个父节点都大于等于其子节点
小堆:任何一个父节点都小于等于其子节点
在这里插入图片描述

3、特点
可以直接得到极值。大堆:根是极大值,小堆:根是极小值。

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

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

相关文章

app逆向实战之定位关键代码

前言 在保证App能够正常使用的前提下,我们可以通过抓包查看是否存在抓包检测。如果可以进行抓包,我们首先进行登录代码定位,并伪造请求进行登录,然后实现App中的某个功能。本文以某嘟牛app为例,抓包结果如下&#xff…

【投标】运维服务方案(2024Word完整版)

1.项目情况 2.服务简述 2.1服务内容 2.2服务方式 2.3服务要求 2.4服务流程 2.5工作流程 2.6业务关系 2.7培训 3.资源提供 3.1项目组成员 3.2服务保障 软件资料清单列表部分文档: 工作安排任务书,可行性分析报告,立项申请审批表&a…

vue后台管理系统 vue3+vite+pinia+elementui+axios下

这篇文章来完成用户组件 也就是增删改查表格 用户页面信息页面由头部&#xff0c;表格,和弹框组成 <template><div class"user-header"><el-button type"primary" click"handleAdd">新增</el-button><el-form :inl…

(2024,LlamaGen,Llama,自回归下一token预测,模型扩展)自回归模型优于扩散:Llama 用于可扩展图像生成

Autoregressive Model Beats Diffusion: Llama for Scalable Image Generation 目录 0. 摘要 1. 引言 2. 自回归模型在图像生成中的应用 2.1 概述 2.2 图像 tokenizer 2.3 自回归模型生成图像 2.4 规模扩展 2.5 服务 3. 实验 5. 结论 0. 摘要 我们介绍 LlamaGen&…

使用mid360从0开始搭建实物机器人入门级导航系统,基于Fast_Lio,Move_Base

Introduction 本文原本只是自己在拿到mid360后&#xff0c;开始进行开发过程的一些问题和学习的记录。毕竟实物和仿真还是有很多不同&#xff0c;且由于碰到的问题也比较多&#xff0c;READEME也越来越详细&#xff0c;所以就干脆整合起来&#xff0c;做成了一篇使用mid360的搭…

嵌入式初学-C语言-十一

#接嵌入式初学-C语言-十,以及部分例题# 循环结构 break和continue break 功能&#xff1a; 1. 用在switch中&#xff0c;用来跳出switch的case语句&#xff1b;如果case没有break&#xff0c;可能会产生case穿透。 2. 用在循环中&#xff08;while、do..while、for..&#…

Linux压缩/解压缩工具:tar命令详解

目录 一、概述 二、基本概念 三、tar命令的基本语法 1、基本语法 2、常用选项 3、帮助获取 四、用法和示例 1. 创建归档文件 &#xff08;1&#xff09;用法 &#xff08;2&#xff09;示例 2. 解压缩归档文件 &#xff08;1&#xff09;用法 &#xff08;2&#…

经典非比较排序—计数排序的Java实现方式

目录 1.具体思路&#xff1a; 2.代码实现&#xff1a; 3.代码分析 4.示例测试&#xff1a; 测试源码&#xff1a; 测试结果&#xff1a; 计数排序&#xff0c;又被称为鸽巢原理&#xff0c;属于桶排序的一种&#xff0c;其本质是通过哈希映射思想&#xff0c;设定计数数组输入以…

音视频入门基础:WAV专题(5)——FFmpeg源码中解码WAV Header的实现

音视频入门基础&#xff1a;WAV专题系列文章&#xff1a; 音视频入门基础&#xff1a;WAV专题&#xff08;1&#xff09;——使用FFmpeg命令生成WAV音频文件 音视频入门基础&#xff1a;WAV专题&#xff08;2&#xff09;——WAV格式简介 音视频入门基础&#xff1a;WAV专题…

论文翻译:Large Language Models in Education: Vision and Opportunities

Large Language Models in Education: Vision and Opportunities 文章目录 教育中的大型语言模型&#xff1a;愿景与机遇摘要1 引言2. 教育与LLMsA. 教育背景B. LLMs背景C. 智能教育D. 教育中的LLMs 3. EduLLMs的关键技术4. LLM赋能教育A. LLMs在教育中的应用B. LLMs下教育的特…

免费分享:全国传统村落空间分布数据(附下载方法)

数据简介 本数据是在中国传统村落名录的基础上&#xff0c;通过地理编码&#xff0c;制作成具有空间坐标信息的矢量数据。 数据属性 数据名称&#xff1a;全国传统村落空间分布数据数据时间&#xff1a;2012年至今&#xff0c;更新至第五批空间位置&#xff1a;全国数据格式&…

opencascade AIS_TrihedronOwner源码学习对象的实体所有者用于选择管理

opencascade AIS_TrihedronOwner 前言 AIS_Trihedron对象的实体所有者用于选择管理。 在OpenCascade的AIS&#xff08;交互对象框架&#xff09;中&#xff0c;管理类似AIS_Trihedron的对象的选择涉及理解如何处理实体&#xff08;或所有者&#xff09;以进行选择。 方法 1…

【单片机毕业设计选题24095】-基于手机端的电池电压采集系统

系统功能: 系统上电后&#xff0c;OLED显示三组18650锂电池电压。 第一行显示第一组锂电池电压 第二行显示第二组锂电池电压 第三行显示第三组锂电池电压 第四行显示电压设定阈值 短按B4按键增加电压设定阈值 短按B5按键减小电压设定阈值 如果任意一组电池电压小于电压…

红酒与季节:品味四季的风情

四季轮转&#xff0c;岁月更迭&#xff0c;每个季节都有其不同的韵味与风情。当定制红酒洒派红酒&#xff08;Bold & Generous&#xff09;与四季相遇&#xff0c;它们共同编织出一幅幅美丽的味觉画卷&#xff0c;让我们在品味中感受四季的风情。 一、春之序曲&#xff1a…

【ESP01开发实例】-ESP-01驱动DHT11和DH22传感器

ESP-01驱动DHT11和DH22传感器 文章目录 ESP-01驱动DHT11和DH22传感器1、DHT11/DHT22传感器介绍2、LCD1602介绍3、硬件准备与接线4、代码实现本主题介绍如何使用 DHT11 和 DHT22 相对湿度和温度传感器与 ESP8266 ESP-01 Wi-Fi 模块,将相对湿度和温度的测量值显示在 162 LCD 屏幕…

C++回顾——多态

一、定义 ①从广义上说,多态性是指&#xff1a;一段程序能够处理多种类型对象的能力。在C语言中,这种多态性可以通过包含多态4种形式来实现。强制多态、重载多态、类型参数化多态、包含多态。 ②从实现上来说&#xff0c;多态的分类&#xff1a;静态多态、动态多态。 二、 广…

云原生安全检测工具(容器安全、trivy、veinmind-tools)

目录 trivy 功能 扫描方式&目标 安装 漏洞库下载及更新 漏洞库扫描原理 官方漏洞库生成 使用 扫描镜像 扫描 wazuh-daemonset 所有漏洞 扫描 wazuh-daemonset 高危、严重漏洞(漏洞过滤) 扫描文件系统 Git 存储库漏洞扫描 报告输出格式 veinmind-tools 1.…

Vue的学习(一)

目录 一、Vue的介绍 二、指令 1.v-text 2.v-html 3.v-show 4.v-if 1&#xff09;v-if与v-show的区别 5.v-else 6.v-else-if 7.v-for 1)v-for 与v-if的优先级 8.v-on&#xff1a;click 9.v-bind 10.v-model 三、表单修饰符 1. .lazy 修饰符 2. .number修饰符…

算法通关:014_2:用队列实现栈

文章目录 题目思路问题总结导包有问题&#xff0c;java提供的有关队列的方法不能调用。queue.add()和queue.offer(n)&#xff0c;这两个方法有什么区别什么叫用LinkedList实现队列 代码结果 题目 LeetCode 225. 用队列实现栈 思路 问题总结 导包有问题&#xff0c;java提供的…