堆的深度剖析及使用

目录

  • 1.堆的创建
    • 1.1初始化
    • 1.2销毁
  • 2.堆的使用
    • 2.1数据插入
    • 2.2堆顶元素
    • 2.3数据删除
  • 3.堆的难点
    • 3.1向上调整
      • 3.1.1视频分析向上调整
      • 3.1.2 代码分析
    • 3.2向下调整
      • 3.2.1视频分析向下调整
      • 3.2.2代码分析

1.堆的创建

堆的物理储存方式其实是一个数组,而逻辑储存方式其实是一个完全二叉树(各各节点从上至下,从左至右依次紧密排列),因此我们可以创建一个结构体的指针指向二叉树的根节点,用数组来存储二叉树的节点。

typedef struct Heap
{HpDate* a;int size;int capacity;	
}HP;

1.1初始化

根据自己的选择可以先将数组a指向空,不开空间,后续插入数据时扩容,如果数据个数确定也可以先开部分空间后续不必扩容操作。

void HPInit(HP* hp)//初始化
{assert(hp);hp->a = NULL;hp->capacity = hp->size = 0;
}

1.2销毁

释放数组a的内存,将a的数据及空间清零以免内存泄漏。

void HPDestory(HP* hp)//销毁
{assert(hp);free(hp->a);hp->capacity = hp->size = 0;
}

2.堆的使用

2.1数据插入

注意事项:数据插入前判断数组空间是否足够(扩容一般二倍扩)

void HPPush(HP* hp, HpDate x)
{assert(hp);if (hp->capacity == hp->size)//插入数据前判断空间是否足够,不够则需要扩容{int newcapacity = hp->capacity == 0 ? 4 : 2 * hp->capacity;//创建新变量记录扩容前的空间大小,以免扩容失败导致原空间被改变HpDate* tmp = (HpDate*)realloc(hp->a, newcapacity * sizeof(HpDate));if (tmp == NULL)//扩容失败报错{perror("realloc faill");exit(1);}//扩容成功转移空间hp->a = tmp;hp->capacity = newcapacity;}hp->a[hp->size++] = x;//莫要忘记将数据个数++AdjustUp(hp->a, hp->size-1);//向上调整
}

2.2堆顶元素

直接返回数组的第一个元素

HpDate HPTop(HP* hp)
{assert(hp);return hp->a[0];
}

2.3数据删除

一般删除堆顶元素,也就是数组中最小的元素

void HPPop(HP* hp)
{assert(hp);swap(hp->a[0], hp->a[hp->size - 1]);hp->size--;AdjustDown(hp->a, 0,hp->size);//向下调整
}

3.堆的难点

3.1向上调整

插入数据后可能不满足小堆,而插入一般是尾插因此要向上调整堆。

3.1.1视频分析向上调整

请添加图片描述

3.1.2 代码分析

细节:在二叉树中左孩子=父亲2+1,右孩子=父亲2+2
如果插入的数据大于父亲或者调整至根(没有父亲)则停止调整。

        //可以传入HP* a而只传入数组只是为了可以供数组的单独使用
void AdjustUp(HpDate* a, HpDate child)//向上调整
{int parent = (child - 1) / 2;while (parent >= 0 && a[parent] > a[child]){swap(a[parent], a[child]);child = parent;parent= (child - 1) / 2;}
}

3.2向下调整

3.2.1视频分析向下调整

请添加图片描述

3.2.2代码分析

          //可以传入HP* a而只传入数组只是为了可以供数组的单独使用
void AdjustDown(HpDate* a, HpDate parent,int n)//向下调整
{int child = parent * 2 + 1;//可以先假设左孩子小if (child + 1 < n && a[child + 1] < a[child])//容易遗漏,不要越界child++;while (a[parent] > a[child]&& child < n){swap(a[parent], a[child]);parent = child;child = parent * 2 + 1;if (child + 1 < n && a[child + 1] < a[child])//容易遗漏,不要越界child++;}
}

向下调整的前提
请添加图片描述

请添加图片描述

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

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

相关文章

Hu矩原理 | cv2中基于Hu矩计算图像轮廓相似度差异的函数cv2.matchShapes【小白记笔记】

Hu 矩&#xff08;Hu Moments&#xff09; 是一种用于描述轮廓形状的 不变特征。它基于图像的矩提取&#xff0c;经过数学变换得到 7 个不变矩&#xff0c;这些不变矩在图像 平移、旋转和缩放等几何变换下保持不变&#xff0c;适合用来衡量轮廓或形状的相似度差异。 1、图像矩…

计算无人机俯拍图像的地面采样距离(GSD)矩阵

引言 在无人机遥感、测绘和精细农业等领域&#xff0c;地面采样距离&#xff08;Ground Sampling Distance&#xff0c;简称 GSD&#xff09;是一个非常重要的指标。GSD 是指图像中每个像素在地面上实际代表的物理距离&#xff0c;通常以米或厘米为单位。GSD 决定了图像的空间…

浅谈怎样系统的准备前端面试

前言 创业梦碎&#xff0c;回归现实&#xff0c;7 月底毅然裸辞&#xff0c;苦战两个月&#xff0c;拿到了美团和字节跳动的 offer&#xff0c;这算是从业以来第一次真正意义的面试&#xff0c;遇到蛮多问题&#xff0c;比如一开始具体的面试过程我都不懂&#xff0c;基本一直是…

2009 ~ 2019 年 408【数据结构】大题解析

2009 年 讲解视频推荐&#xff1a;【BOK408真题讲解-2009年&#xff08;催更就退网版&#xff09;】 1. 图的应用&#xff08;10’&#xff09; 带权图&#xff08;权值非负&#xff0c; 表示边连接的两顶点间的距离&#xff09;的最短路径问题是找出从初始顶点到目标顶点之间…

时空AI赋能低空智能科技创新

随着人工智能技术的不断进步&#xff0c;时空人工智能&#xff08;Spatio-Temporal AI&#xff0c;简称时空AI&#xff09;正在逐渐成为推动低空经济发展的新引擎。时空AI结合了地理空间智能、城市空间智能和时空大数据智能&#xff0c;为低空智能科技创新提供了强大的数据支持…

Python读取Excel批量写入到PPT生成词卡

一、问题的提出 有网友想把Excel表中的三列数据&#xff0c;分别是&#xff1a;单词、音标和释义分别写入到PPT当中&#xff0c;每一张PPT写一个单词的内容。这种批量操作是python的强项&#xff0c;尤其是在办公领域&#xff0c;它能较好地解放双手&#xff0c;读取Excel表后…

Proteus(8.15)仿真下载安装过程(附详细安装过程图)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 前言 一、Proteus是什么&#xff1f; 二、下载链接 三、下安装步骤 1.解压&#xff0c;有键管理员运行 2.点击Next&#xff0c;进行下一步 3.勾选I accept…&#…

动态导出word文件支持转pdf

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、功能说明二、使用步骤1.controller2.工具类 DocumentUtil 导出样式 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 例如&#xff…

紧固件设计之——开槽六角头防脱出杆螺栓仿真APP

按照产品形态分类&#xff0c;紧固件通常包括以下12类&#xff1a;螺栓、螺柱、螺钉、螺母、自攻螺钉、木螺钉、垫圈、挡圈、销、铆钉、焊钉、组合件与连接副&#xff0c;是一类用于连接和固定各种构件和零部件的重要机械零件&#xff0c;可确保机械装置或设备结构的牢固和稳定…

mysql中与并发相关的问题?

今天我们来聊聊 MySQL 中与并发相关的一些问题。作为一名资深 Python 开发工程师&#xff0c;我觉得这些问题不仅关乎数据库的稳定性和数据的一致性&#xff0c;更与我们的代码实现和业务逻辑密切相关。 尤其是在高并发环境下&#xff0c;如何保证数据的一致性&#xff0c;如何…

使用k6进行kafka负载测试

1.安装环境 kafka环境 参考Docker搭建kafka环境-CSDN博客 xk6-kafka环境 ./xk6 build --with github.com/mostafa/xk6-kafkalatest 查看安装情况 2.编写脚本 test_kafka.js // Either import the module object import * as kafka from "k6/x/kafka";// Or in…

[机器学习]XGBoost(3)——确定树的结构

XGBoost的目标函数详见[机器学习]XGBoost&#xff08;2&#xff09;——目标函数&#xff08;公式详解&#xff09; 确定树的结构 之前在关于目标函数的计算中&#xff0c;均假设树的结构是确定的&#xff0c;但实际上&#xff0c;当划分条件不同时&#xff0c;叶子节点包含的…

springboot444新冠物资管理系统的设计与实现(论文+源码)_kaic

摘 要 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装新冠物资管理系统软件来发挥其高效地信息处理的作用&#x…

Javascript-web API-day02

文章目录 01-事件监听02-点击关闭广告03-随机点名案例04-鼠标经过或离开事件05-可点击的轮播图06-小米搜索框07-键盘类型事件08-键盘事件-发布评论案例09-focus选择器10-评论回车发布11-事件对象12-trim方法13-环境对象14-回调函数15-tab栏切换 01-事件监听 <!DOCTYPE html…

使用xjar 对Spring-Boot JAR 包加密运行

1 Xjar 介绍 Spring Boot JAR 安全加密运行工具&#xff0c;同时支持的原生JAR。 基于对JAR包内资源的加密以及拓展ClassLoader来构建的一套程序加密启动&#xff0c;动态解密运行的方案&#xff0c;避免源码泄露或反编译。 功能特性 无需侵入代码&#xff0c;只需要把编译好的…

深度学习的下一站:解锁人工智能的新边界

引言&#xff1a;新边界的呼唤 深度学习的诞生&#xff0c;犹如人工智能领域的一次革命&#xff0c;激发了语音助手、自动驾驶、智能医疗等前沿技术的飞速发展。然而&#xff0c;面对现实世界的复杂性&#xff0c;现有的深度学习模型仍然存在数据依赖、可解释性差、环境适应力不…

基于DockerCompose搭建Redis主从哨兵模式

linux目录结构 内网配置 哨兵配置文件如下&#xff0c;创建3个哨兵配置文件 # sentinel26379.conf sentinel26380.conf sentinel26381.conf 内容如下 protected-mode no sentinel monitor mymaster redis-master 6379 2 sentinel down-after-milliseconds mymaster 60000 s…

upload-labs靶场1-19关

第 1 关&#xff08;删除前端js校验&#xff09; 点击第一关&#xff0c;我们可以看到页面上传区可以上传一个图片&#xff0c;我们要上传一个 webshell&#xff0c;这里我们上传一句话木马的 php 点击上传 显示文件不支持上传&#xff0c;这时我们查看源码 查看代码后发现&am…

vue3+vite 引入动画组件库 Inspira UI

关于Inspira UI Inspira UI不是传统的组件库。相反&#xff0c;它是精选的优雅组件集合&#xff0c;您可以轻松将其集成到您的应用程序中。只需选择所需的组件&#xff0c;复制代码&#xff0c;然后自定义以适合您的项目即可。您可以随意使用和修改代码&#xff01; 官网地址…

Go语言启动独立进程

文章目录 问题解决方案1. **将 npc.exe 启动为独立的进程**2. **修改 exec.Command 函数**示例代码解释为什么这样有效注意 问题 在你当前的代码中&#xff0c;调用 exec.Command("XXX.exe") 启动 XXX.exe 程序时&#xff0c;这个程序是由 Go 程序直接启动的。如果 …