算法通关村第十四关-青铜挑战认识堆

大家好我是苏麟 , 今天带大家认识认识堆 .

堆是将一组数据按照完全二叉树的存储顺序,将数据存储在一个一维数组中的结构。

堆有两种结构,一种称为大顶堆,一种称为小顶堆 :

大顶堆

大顶堆的任何一个父节点的值,都大于或等于它左、右孩子 节点的值。

小顶堆

最小堆的任何一个父节点的值,都小于或等于它左、右孩子 节点的值。


堆的根节点叫作堆顶

大顶堆小顶堆 的特点决定了:大顶堆 的堆顶是整个堆中的最大元素;小顶堆的堆顶是整个堆中的最小元素。

堆的自我调整

所谓堆的自我调整,就是把一个不符合堆性质的完全二叉树,调整成一个堆 .

下面让我们以最小堆为例,看一看二叉堆是如何 进行自我调整的

插入节点

当堆插入节点时,插入位置是完全二叉树的最后一个位置。例如插入一个 新节点,值是 0

这时,新节点的父节点 5 比 0 大,显然不符合最小堆的性质。于是让新节点"上 浮",和父节点交换位置

继续用节点 0 和父节点 3 做比较,因为 0 小于 3,则让新节点继续"上浮"

继续比较,最终新节点 0 "上浮"到了堆顶位置

这就是插入的过程 .

删除节点

堆删除节点的过程和插入节点的过程正好相反,所删除的是处于堆顶的节点。例如删除最小堆的堆顶节点 1

这时,为了继续维持完全二叉树的结构,我们把堆的最后一个节点 10 临时补到 原本堆顶的位置

接下来,让暂处堆顶位置的节点10和它的左、右孩子进行比较,如果左、右孩子节点中最小的一个(显然是节点2)比节点10小,那么让节点10"下沉"

继续让节点10和它的左、右孩子做比较,左、右孩子中最小的是节点7,由于10 大于7,让节点10继续"下沉"

这样一来,二叉堆重新得到了调整

大家好好理解一下 .

这期就到这里 , 下期见!

相关推荐
SelectDB9 分钟前
十亿 JSON 秒级响应:Apache Doris vs ClickHouse,Elasticsearch,PostgreSQL
算法
小七mod13 分钟前
【Spring】Spring Boot自动配置的案例
java·spring boot·spring·自动配置·源码·ioc·aop
红石榴花生油22 分钟前
Docker + Nginx 部署 Java 项目(JAR 包 + WAR 包)实战笔记
java·tomcat·maven
带刺的坐椅25 分钟前
Solon AI 开发学习 - 1导引
java·ai·openai·solon·mcp
sg_knight27 分钟前
RabbitMQ 中的预取值(prefetch)详解:如何真正提升消费端性能?
java·spring boot·spring·spring cloud·消息队列·rabbitmq·预取值
Dxxyyyy36 分钟前
零基础学JAVA--Day34(Map接口+HashTable+HashMap+TreeSet+TreeMap+开发中如何选择集合实现类?(重要))
java·开发语言
橘颂TA37 分钟前
【剑斩OFFER】算法的暴力美学——除自身以外数组的乘积
算法·leetcode·职场和发展·结构与算法
源码之家38 分钟前
机器学习:基于python租房推荐系统 预测算法 协同过滤推荐算法 房源信息 可视化 机器学习-线性回归预测模型 Flask框架(源码+文档)✅
大数据·python·算法·机器学习·数据分析·线性回归·推荐算法
鑫—萍1 小时前
C/C++精品算法——双指针(1)
c语言·c++·算法
铭哥的编程日记1 小时前
深入浅出蓝桥杯:算法基础概念与实战应用(三)搜索
算法·蓝桥杯·深度优先