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

【初阶数据结构】 归序而上的云阶 堆

点击展开/收起 文章目录文章目录1.堆的概念2.堆的接口实现堆的定义2.1 堆的初始化2.2 堆的销毁2.3 获取堆顶数据2.4 堆的向下调整2.5 堆的向上调整2.6 堆的插入2.7 堆顶数据删除2.8 堆的判空3.完整代码展示Heap.hHeap.c4.建堆方法1.向上调整建堆2.向下调整建堆希望读者们多多三连支持小编会继续更新你们的鼓励就是我前进的动力1.堆的概念堆是一种树形结构,本次我用数组来演示实现,属于完全二叉树,简单来说完全二叉树就是,除了最后一层每层都要是满的在讲解结构之前,我们讲解一个概念,父节点子节点,父节点是相对于子节点来说的,每一个节点都可以算是他下一层的父节点,直线相连的就是他的孩子就是子节点最后一层没有子节点堆的结构分类:1.大堆父节点一定要比所有子节点大子节点之间没有顺序要求2.小堆父节点一定要比所有子节点小子节点之间没有顺序要求2.堆的接口实现堆的定义与销毁初始化,与顺序表完全一致,这里不做过多的讲解,不会的可以去看看顺序表篇堆的定义typedefintHeapDataType;typedefstructHeapNode{HeapDataType*a;intsize;intcapacity;}Heap;2.1 堆的初始化voidHeapInit(Heap*ph){ph-aNULL;ph-capacityph-size0;}2.2 堆的销毁voidHeapDestory(Heap*ph){assert(ph);free(ph-a);ph-aNULL;ph-capacityph-size0;}2.3 获取堆顶数据堆顶数据就是第一个a[0]HeapDataTypeHeapTop(Heap*ph){assert(ph);assert(ph-size0);returnph-a[0];}在讲解向下调整之前我要讲讲父子节点关系由图可见;我们可以找到两种关系,child parent * 2 1parent (child - 1) / 2;(在这里会有child为偶数情况,(child-1)/2丢数据后的计算结果刚好是父节点)2.4 堆的向下调整主要目的:可以通过条件把小的数据往下调整,大的数据往上调,可以把最大的数据到最上面(这里只是是演示)可改变条件if (a[parent] a[child])达到相反的目的voidHeapDown(HeapDataType*a,intsize,intparent){//int parent 0;//注意这里不要写死了要传一个parentintchildparent*21;while(childsize)//孩子一定在数组范围了不可越界了{//判断左右孩子的大小,第一个条件是限制右孩子存在,只有右孩子存在才有可比性if(child1sizea[child]a[child1]){child;}if(a[parent]a[child]){Swap(a[parent],a[child]);parentchild;childparent*21;}else{//不满足时调到底了break;}}}2.5 堆的向上调整主要目的:可以通过条件把小的数据往上调整,大的数据往下调,可以把最小的数据到最上面(这里只是是演示)可改变条件if (a[parent] a[child])达到相反的目的voidHeapUp(HeapDataType*a,HeapDataType x,intsize){a[size]x;intchildsize;intparent0;while(child0){parent(child-1)/2;if(a[parent]a[child]){//这里就是普通的传指针交换数据Swap(a[parent],a[child]);}else{//不满足时调到底了break;}childparent;}}2.6 堆的插入我在这里建的是小堆voidHeapPush(Heap*ph,HeapDataType x){if(ph-sizeph-capacity){intnewcapacityph-capacity0?4:ph-capacity*2;HeapDataType*tmprealloc(ph-a,sizeof(HeapDataType)*newcapacity);if(tmpNULL){perror(realloc fail);exit(-1);}ph-atmp;ph-capacitynewcapacity;}//每次尾插数据,向上调整,把他跳到正确的位置,如果小了就往上走HeapUp(ph-a,x,ph-size);ph-size;}2.7 堆顶数据删除删除要保证删除后的数组还是一个堆,所以思路是把堆顶数据交换到堆尾,再向下调成新堆voidHeapPop(Heap*ph){assert(ph);assert(ph-size0);Swap(ph-a[0],ph-a[ph-size-1]);ph-size--;HeapDown(ph-a,ph-size);}2.8 堆的判空boolHeapEmpty(Heap*ph){returnph-size0;}3.完整代码展示Heap.h#includestdbool.h#includeassert.htypedefintHeapDataType;typedefstructHeapNode{HeapDataType*a;intsize;intcapacity;}Heap;//堆的初始化voidHeapInit(Heap*ph);//堆的销毁voidHeapDestory(Heap*ph);//获取堆顶数据HeapDataTypeHeapTop(Heap*ph);//堆的插入voidHeapPush(Heap*ph,HeapDataType x);//堆顶数据删除voidHeapPop(Heap*ph);//堆的判空boolHeapEmpty(Heap*ph);//堆的向下调整voidHeapDown(HeapDataType*a,intsize,intparent);//堆的向上调整voidHeapUp(HeapDataType*a,HeapDataType x,intsize);Heap.cvoidHeapInit(Heap*ph){ph-aNULL;ph-capacityph-size0;}voidHeapDestory(Heap*ph){assert(ph);free(ph-a);ph-aNULL;ph-capacityph-size0;}voidSwap(int*pa,int*pb){intc0;c*pb;*pb*pa;*pac;}voidHeapUp(HeapDataType*a,HeapDataType x,intsize){a[size]x;intchildsize;intparent0;while(child0){parent(child-1)/2;if(a[parent]a[child]){Swap(a[parent],a[child]);}else{break;}childparent;}}voidHeapPush(Heap*ph,HeapDataType x){if(ph-sizeph-capacity){intnewcapacityph-capacity0?4:ph-capacity*2;HeapDataType*tmprealloc(ph-a,sizeof(HeapDataType)*newcapacity);if(tmpNULL){perror(realloc fail);exit(-1);}ph-atmp;ph-capacitynewcapacity;}HeapUp(ph-a,x,ph-size);ph-size;}voidHeapDown(HeapDataType*a,intsize,intparent){//int parent 0;//注意这里不要写死了要传一个parentintchildparent*21;while(childsize){if(child1sizea[child]a[child1]){child;}if(a[parent]a[child]){Swap(a[parent],a[child]);parentchild;childparent*21;}else{break;}}}voidHeapPop(Heap*ph){assert(ph);assert(ph-size0);Swap(ph-a[0],ph-a[ph-size-1]);ph-size--;HeapDown(ph-a,ph-size);}HeapDataTypeHeapTop(Heap*ph){assert(ph);assert(ph-size0);returnph-a[0];}boolHeapEmpty(Heap*ph){returnph-size0;}我们为什么要有堆这个数据结构,因为在建成一个堆后,他的堆顶数据,大堆一定是最大的数,小堆一定是最小的数,**我们只需要每次把堆顶数据与最后一个数据交换再建新堆,就可以把数据排的有序,**在后面我会在八大排序专门讲解堆排序,还有个作用就是可以解决TopK问题,在下一次博客我会专门讲解Topk问题.下来我讲讲快速建堆的方法;4.建堆方法1.向上调整建堆voidHeapUp(HeapDataType*a,HeapDataType x,intsize){a[size]x;intchildsize;intparent0;while(child0){parent(child-1)/2;if(a[parent]a[child]){//这里就是普通的传指针交换数据Swap(a[parent],a[child]);}else{//不满足时调到底了break;}childparent;}}for(inti1;i11;i){HeapUp(a,i,size);}2.向下调整建堆voidHeapDown(HeapDataType*a,intsize,intparent){//int parent 0;//注意这里不要写死了要传一个parentintchildparent*21;while(childsize)//孩子一定在数组范围了不可越界了{//判断左右孩子的大小,第一个条件是限制右孩子存在,只有右孩子存在才有可比性if(child1sizea[child]a[child1]){child;}if(a[parent]a[child]){Swap(a[parent],a[child]);parentchild;childparent*21;}else{//不满足时调到底了break;}}}for(intisize-1;i0;i--){//从倒数第二层开始向下调整HeapDown(a,i,(i-2)/2);}这里有两种建堆方法谁更有优势呢,我们该选择哪一种呢?这里我们就要计算一下建堆的复杂度向上调整的复杂度计算向下调整的复杂都计算希望读者们多多三连支持小编会继续更新你们的鼓励就是我前进的动力

相关文章:

【初阶数据结构】 归序而上的云阶 堆

📖 点击展开/收起 文章目录 文章目录 1.堆的概念2.堆的接口实现堆的定义2.1 堆的初始化2.2 堆的销毁2.3 获取堆顶数据2.4 堆的向下调整2.5 堆的向上调整2.6 堆的插入2.7 堆顶数据删除2.8 堆的判空 3.完整代码展示Heap.hHeap.c 4.建堆方法1.向上调整建堆2.向下调整建…...

VH6501干扰测试进阶:用CAPL脚本精准控制错误帧的‘连发’与‘间隔’(Repetitions类详解)

VH6501干扰测试进阶:用CAPL脚本精准控制错误帧的‘连发’与‘间隔’(Repetitions类详解) 在汽车电子测试领域,VH6501作为一款专业的CAN总线干扰接口,其核心价值在于能够模拟真实世界中复杂多变的通信故障场景。而真正区…...

Kubernetes网络管理:从CNI到Ingress的全面解析

Kubernetes网络管理:从CNI到Ingress的全面解析 🔥 硬核开场 各位技术大佬们,今天咱们来聊聊Kubernetes网络管理。别以为Kubernetes的网络就是简单的IP分配,实际上它涉及CNI插件、Service、Ingress、NetworkPolicy等多个组件&#…...

Qwen3.5-27B企业落地指南:电商客服/教育答疑/办公提效三大场景应用

Qwen3.5-27B企业落地指南:电商客服/教育答疑/办公提效三大场景应用 1. 企业级AI助手的新选择 在数字化转型浪潮中,企业正寻求更智能的解决方案来提升运营效率。Qwen3.5-27B作为一款视觉多模态理解模型,为企业提供了全新的AI助手选择。这款模…...

从ChatGPT的‘提示词’到图像修复:PromptIR如何用‘提示学习’教会AI看图说话并‘修图’?

PromptIR:当提示学习遇见图像修复,AI如何像ChatGPT一样"看图说话" 你是否曾经对着模糊的老照片叹气,或是被雾霾笼罩的风景照感到无奈?图像修复技术正以前所未有的速度发展,而最新突破PromptIR将自然语言处理…...

别再死记硬背公式了!手把手带你画图推导‘放苹果’问题的状态转移方程

可视化拆解动态规划:从画图到推导‘放苹果’问题的本质 在算法学习的道路上,动态规划(DP)常常是让初学者望而生畏的难关。那些看似神奇的递推公式,往往被当作黑盒魔法般死记硬背。今天,我们要彻底改变这种学…...

D14: 周复盘:人是核心,工具是杠杆

文章目录 D14: 周复盘:人是核心,工具是杠杆 🎯 本周回顾:都发生了什么? 第一周的大事记 数据不会说谎 核心复盘内容 复盘维度一:人的层面——谁在进步,谁在旁观? 复盘维度二:工具层面——哪些工具真的在产生价值? 复盘维度三:流程层面——AI 改变了什么,没改变什么…...

JiYuTrainer深度解析:极域电子教室反控制技术架构揭秘

JiYuTrainer深度解析:极域电子教室反控制技术架构揭秘 【免费下载链接】JiYuTrainer 极域电子教室防控制软件, StudenMain.exe 破解 项目地址: https://gitcode.com/gh_mirrors/ji/JiYuTrainer JiYuTrainer是一款针对极域电子教室系统的专业反控制软件&#…...

1 7.2 网卡的设置

🔥个人主页:杨利杰YJlio❄️个人专栏:《Sysinternals实战教程》《Windows PowerShell 实战》《WINDOWS教程》《IOS教程》《微信助手》《锤子助手》 《Python》 《Kali Linux》 《那些年未解决的Windows疑难杂症》🌟 让复杂的事情更…...

实测对比:Faster-LIO vs FastLIO2,iVox到底让我的Livox Mid360快了多少?

Faster-LIO与FastLIO2性能实测:iVox如何提升Livox Mid360的SLAM效率 当Livox Mid360固态激光雷达以每秒240,000点的速度扫描环境时,传统基于ikd-tree的SLAM算法常面临计算瓶颈。去年我们团队在无人机巡检项目中就遭遇过这样的困境——FastLIO2在复杂植被…...

Claude API 注册被拒?国内开发者最全绕坑指南

作为一名在AI工具堆里摸爬滚打的国内开发者,Claude API注册那道坎,我算是结结实实摔过跟头。前阵子为了接入Claude做合同解析工具,光注册就折腾了快一周,踩过的坑能凑成一本"血泪史"。最初我抱着侥幸心理,用…...

终极指南:如何用ViGEmBus虚拟手柄驱动解决Windows游戏兼容性问题

终极指南:如何用ViGEmBus虚拟手柄驱动解决Windows游戏兼容性问题 【免费下载链接】ViGEmBus Windows kernel-mode driver emulating well-known USB game controllers. 项目地址: https://gitcode.com/gh_mirrors/vi/ViGEmBus 你是否曾为心爱的Switch手柄无法…...

马斯克五步法实战:用Notion和飞书搭建你的个人效率系统(附模板)

马斯克五步法实战:用Notion和飞书搭建你的个人效率系统(附模板) 在信息爆炸的时代,个人知识管理和团队协作效率成为职场竞争力的关键分水岭。埃隆马斯克创立的五步工作法(需求验证→流程简化→持续优化→快速迭代→全面…...

2025_NIPS_iVideoGPT: Interactive VideoGPTs are Scalable World Models

文章核心内容与创新点总结 核心内容 iVideoGPT 是一款基于自回归Transformer的可扩展世界模型,通过融合视觉观测、动作、奖励等多模态信号,实现交互式环境模拟。其核心是先在百万级人类与机器人操作轨迹上预训练,再针对下游任务(动作条件视频预测、视觉规划、基于模型的强…...

Windows 10系统精简终极指南:如何用开源工具让你的电脑快如闪电?

Windows 10系统精简终极指南:如何用开源工具让你的电脑快如闪电? 【免费下载链接】Win10BloatRemover Configurable CLI tool to easily and aggressively debloat and tweak Windows 10 by removing preinstalled UWP apps, services and more. Origina…...

AI视频字幕去除技术革命:3分钟掌握专业级硬字幕清理方案

AI视频字幕去除技术革命:3分钟掌握专业级硬字幕清理方案 【免费下载链接】video-subtitle-remover 基于AI的图片/视频硬字幕去除、文本水印去除,无损分辨率生成去字幕、去水印后的图片/视频文件。无需申请第三方API,本地实现。AI-based tool …...

如何用CardEditor将桌游卡牌设计效率提升300%:新手完整指南

如何用CardEditor将桌游卡牌设计效率提升300%:新手完整指南 【免费下载链接】CardEditor 一款专为桌游设计师开发的批处理数值填入卡牌生成器/A card batch generator specially developed for board game designers 项目地址: https://gitcode.com/gh_mirrors/ca…...

麒麟V10/龙蜥arm架构二进制安装mysql8.0.36

一、安装前环境监测 在MySQL被收购后,MySQL最初的作者担心MySQL存在闭源的风险,在MySQL的分支上开发了mariadb。后来一些Linux分发版就将mariadb作为系统默认安装的数据库系统 rpm -qa |grep -i mariadb#可能显示的结果:mariadb-libs-5.5.6…...

【nanobot】 实战与二次开发:4000 行代码,一套完整的 【AI Agent】 框架

🐈 nanobot 实战与二次开发:4000 行代码,一套完整的 AI Agent 框架 🤵‍♂️ 个人主页:小李同学_LSH的主页 ✍🏻 作者简介:LLM学习者 🐋 希望大家多多支持,我们一起进步&…...

从“定比分点”到“交比不变”:用初中三角形面积公式,轻松理解射影几何的核心定理

从“定比分点”到“交比不变”:用初中三角形面积公式,轻松理解射影几何的核心定理 数学的魅力往往藏在我们最熟悉的工具里。当你第一次听说"射影几何"时,脑海中浮现的可能是复杂的坐标系和晦涩的符号——但今天,我要带你…...

CentOS系统------DBMS

逻辑梳理一、准备工作 # 切换到root或使用sudo su - 二、安装 Apache sudo yum install -y httpd sudo systemctl start httpd sudo systemctl enable httpd 三、安装 PHP 环境 sudo yum install -y php php-mysqlnd php-json php-mbstring sudo systemctl restart httpd 四、安…...

告别JIT编译卡顿:用.NET 8.0 AOT编译你的第一个独立Web API(附完整配置流程)

告别JIT编译卡顿:用.NET 8.0 AOT编译你的第一个独立Web API(附完整配置流程) 你是否经历过这样的场景:深夜上线新版本,服务器刚启动就被用户投诉"请求超时"?监控面板上那条刺眼的冷启动曲线&…...

释放存储空间:你的免费开源视频图像压缩神器

释放存储空间:你的免费开源视频图像压缩神器 【免费下载链接】compressO Convert any video/image into a tiny size. 100% free & open-source. Available for Mac, Windows & Linux. 项目地址: https://gitcode.com/gh_mirrors/co/compressO 你是否…...

Agent记忆架构设计剖析系列:原理、权衡与场景适配(hermes设计原理)

Hermes 是一款主打 “自我进化” 的 Agent 框架,其记忆系统的核心设计哲学是认知经济性—— 即 “只记住对未来行为有价值的信息”,通过严格的记忆审查与精炼机制,将有限的计算资源集中于高价值记忆,实现了记忆质量与系统效率的平…...

STM32H743+SOEM+英威腾DA200伺服:一个嵌入式EtherCAT主站的完整调试笔记(含代码)

STM32H743与英威腾DA200伺服的EtherCAT主站实战:从硬件搭建到运动控制 在工业自动化领域,实时以太网通信协议EtherCAT因其卓越的性能和灵活性正成为运动控制系统的首选方案。本文将分享一个基于STM32H743微控制器和SOEM开源库实现EtherCAT主站控制英威腾…...

抖音无水印视频下载终极指南:3步实现高效批量下载与智能管理

抖音无水印视频下载终极指南:3步实现高效批量下载与智能管理 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback…...

避坑指南:STM32H7的SD卡虚拟U盘项目,为什么加了FreeRTOS后USB读写就挂了?

STM32H7虚拟U盘开发实战:FreeRTOS环境下USB与SD卡协同设计精要 在嵌入式存储解决方案中,将SD卡通过USB接口模拟为U盘是常见需求。当项目从裸机迁移到FreeRTOS环境时,原本稳定的USB大容量存储类(MSC)功能可能突然失效—…...

real-anime-z快速上手指南:无需代码,通过WebUI生成高质量动漫图

real-anime-z快速上手指南:无需代码,通过WebUI生成高质量动漫图 1. 模型简介 real-anime-z是基于Z-Image的LoRA版本开发的文生图模型,专注于生成高质量的动漫风格图片。这个模型通过Xinference部署,并提供了基于Gradio的WebUI界…...

金蝶云单据下推避坑指南:当子单据体遇上复杂条件,我这样用插件搞定

金蝶云单据下推高阶实战:复杂条件与跨层级数据抓取全解析 当你在金蝶云项目中遇到需要根据特定条件筛选子单据体数据,并且还要跨层级获取基础资料值时,是否感到无从下手?本文将带你深入剖析这个典型业务场景的解决方案。 1. 复杂下…...

Re:Linux系统篇(六)权限篇 · 一:用户切换与进程嵌套sudo提权与sudoers设置精讲

◆ 博主名称: 晓此方-CSDN博客 大家好,欢迎来到晓此方的博客。 ⭐️Linux系列个人专栏: 【主题曲】Linux ⭐️Re系列专栏:我们思考 (Rethink) 我们重建 (Rebuild) 我们记录 (Record) 文章目录概要&序論1.1用户切换指令1.1.…...