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

【数据结构与算法】堆(大顶堆小顶堆堆排序)

‍ 关于作者会编程的土豆“不是因为看见希望才坚持而是坚持了才看见希望。”你好我是会编程的土豆一名热爱后端技术的Java学习者。正在更新中的专栏《数据结构与算法》《leetcode hot 100》作者简介后端学习者什么是堆排序大顶堆每个节点值 ≥ 子节点值。根节点最大。小顶堆每个节点值 ≤ 子节点值。根节点最小。用数组存储完全二叉树索引关系从0开始父节点i→ 左子2i1右子2i2子节点i→ 父节点⌊(i-1)/2⌋代码实现#include iostream #include vector using namespace std; // 下沉调整维护大顶堆性质 void heapify(vectorint arr, int i, int heapSize) { int largest i; // 假设当前节点最大 int left 2 * i 1; // 左子节点 int right 2 * i 2; // 右子节点 // 找出父、左、右三者中的最大值 if (left heapSize arr[left] arr[largest]) largest left; if (right heapSize arr[right] arr[largest]) largest right; // 如果最大值不是父节点交换并递归调整 if (largest ! i) { swap(arr[i], arr[largest]); heapify(arr, largest, heapSize); } } void heapSort(vectorint arr) { int n arr.size(); // 1. 建堆从最后一个非叶子节点开始下沉 for (int i n / 2 - 1; i 0; --i) heapify(arr, i, n); // 2. 排序逐个将堆顶最大值移到末尾 for (int i n - 1; i 0; --i) { swap(arr[0], arr[i]); // 交换堆顶和末尾 heapify(arr, 0, i); // 调整剩余堆 } } // 测试 int main() { vectorint arr {4, 6, 8, 5, 9}; heapSort(arr); for (int x : arr) cout x ; // 输出4 5 6 8 9 return 0; }如何实现堆排序一个关键操作 ——Heapify堆化/下沉这是堆排序的发动机。它的作用很专一当你有一个节点它的左右子树都已经是大顶堆了但唯独这个节点本身可能不满足堆的性质时Heapify能通过比较和交换把这个节点“下沉”到正确的位置从而让整棵树重新成为一个合法的大顶堆。具体步骤找出当前节点i、它的左子节点left和右子节点right三者中值最大的那个。如果最大的就是i自己那说明它已经在正确位置了操作结束。如果最大的不是i比如是左子节点那就把i和左子节点的值交换。交换后i原来的大值被移走了而换下来的小值可能又会破坏左子树的堆性质。所以我们需要递归地对发生交换的那个子节点再次执行Heapify直到整个子树都满足堆的性质。void heapify(std::vectorint arr, int n, int i) { int largest i; int left 2 * i 1; int right 2 * i 2; if (left n arr[left] arr[largest]) largest left; if (right n arr[right] arr[largest]) largest right; if (largest ! i) { std::swap(arr[i], arr[largest]); heapify(arr, n, largest); // 递归调整被影响的下层节点 } }说人话先从最底部开始比较左右节点及自己然后最大的换到根的位置然后继续比较换下来的节点的自身和他的左右还有继续向上比较先从最底部开始比较左右节点及自己然后最大的换到根的位置// 从最后一个非叶子节点开始自下而上 for (int i n / 2 - 1; i 0; --i) { heapify(arr, n, i); }向下比较下沉在heapify函数内部换下来的小值会递归地和它新位置的子节点比这是向下走。向上比较循环for循环的i--会处理上一个非叶子节点这是向上走面试里不会让你默写堆的定义而是什么看你能否识别出问题可以用堆来高效解决。Top K 问题在百万/亿级数据中找出最大/最小的 K 个元素。典型题目LeetCode 215. 数组中的第K个最大元素。思路求最大 K 个用小顶堆维持堆大小为 K遍历数据比堆顶大就替换并调整。数据流中的中位数数据源源不断到来随时能求出当前所有数据的中位数。典型题目LeetCode 295. 数据流的中位数。思路使用两个堆一个大顶堆存较小的一半一个小顶堆存较大的一半保持两个堆大小平衡。合并 K 个有序链表/数组典型题目LeetCode 23. 合并K个升序链表。思路用小顶堆维护每个链表当前的头部节点每次弹出最小值极大提升归并效率。带权图的最短路径典型题目Dijkstra 算法。思路用小顶堆作为优先队列每次高效取出当前距离起点最近且未确定最短路径的节点。

相关文章:

【数据结构与算法】堆(大顶堆小顶堆堆排序)

👨‍💻 关于作者:会编程的土豆 “不是因为看见希望才坚持,而是坚持了才看见希望。” 你好,我是会编程的土豆,一名热爱后端技术的Java学习者。 📚 正在更新中的专栏: 《数据结构与算…...

Mem Reduct内存管理功能完全指南:从基础设置到高级优化

Mem Reduct内存管理功能完全指南:从基础设置到高级优化 【免费下载链接】memreduct Lightweight real-time memory management application to monitor and clean system memory on your computer. 项目地址: https://gitcode.com/gh_mirrors/me/memreduct M…...

别再对着黑乎乎的标签图发愁了!手把手教你给农业大棚遥感数据集上色(附Python代码)

农业大棚遥感数据可视化:用Python给黑白标签注入色彩生命 当你第一次打开农业大棚遥感数据集的标签文件时,那片漆黑是否让你感到困惑?作为一名刚接触遥感图像分割的开发者,我完全理解这种挫败感——你明明知道这些像素值代表着不同…...

一文搞懂 Spring Cloud:从入门到实战的微服务全景指南(建议收藏)盼

一、中间件是啥?咱用“餐厅”打个比方 想象一下,你的FastAPI应用是个高级餐厅。 ?? 顾客(客户端请求)来到门口。- 迎宾(CORS中间件):先看你是不是从允许的街区(域名)来…...

PD 2.0 与 PD 3.0 深度解析:从固定档位到 PPS 精细化供电的技术演进

USB Power Delivery(USB PD)是USB-IF制定的通用快充与供电协议,依托Type-C接口实现高功率、多功能电力传输,已成为手机、笔记本、平板、外设等设备的主流供电标准。PD 2.0奠定高功率快充基础,PD 3.0则以PPS可编程电源为…...

PyCharm虚拟环境配置避坑指南:为什么你的模块导入有提示但运行报错?

PyCharm虚拟环境配置避坑指南:为什么你的模块导入有提示但运行报错? 作为Python开发者,PyCharm的智能提示功能是我们日常开发的重要助力。但你是否遇到过这样的情况:明明在虚拟环境中安装了模块,代码运行时一切正常&am…...

Swift学习笔记21-内存管理

// // main.swift // class21 内存管理(面试题为主,基本都过气了,没实践意义) // // Created by sakiko on 2026/4/7. //import Foundationprint("Hello, World!")//Swift 使用自动引用计数(ARC&#xff…...

2026应用质量监控Bugly:全平台高效定位与统一管理实践

2026应用质量监控Bugly:全平台高效定位与统一管理实践 随着移动与泛终端应用进入多平台、多架构、全球化并行演进的阶段,研发流程对质量监控的实时性、跨端一致性与闭环处置能力提出更高要求。企业不仅要快速捕获崩溃与性能异常,更需在复杂环…...

超算新手避坑指南:第一次用Slurm提交MATLAB作业就成功的5个关键点

超算新手避坑指南:第一次用Slurm提交MATLAB作业就成功的5个关键点 第一次在超算平台上用Slurm提交MATLAB作业,就像在陌生的城市里开车——即使有导航,也难免会错过几个路口。作为过来人,我完全理解那种看着作业失败却不知从何查起…...

R语言实战:用mice包搞定缺失值多重插补(附完整代码+避坑指南)

R语言实战:用mice包实现缺失值多重插补的完整解决方案 1. 缺失值处理的挑战与多重插补原理 在实际数据分析工作中,我们经常会遇到数据缺失的情况。传统方法如直接删除缺失记录或简单均值填充往往会导致信息损失或统计偏差。多重插补(Multiple Imputation…...

别再只问ChatGPT了!实测混元、DeepSeek、通义千问的数学解题能力,附保姆级API调用避坑指南

三大数学大模型API实战测评:从注册到调用的全流程避坑指南 当我们需要在项目中集成数学解题能力时,市面上主流的大模型API各有千秋。本文将带您深入体验混元、DeepSeek和通义千问三大模型的API调用全流程,从账号注册到结果解析,手…...

OpenVINO-Audacity插件:AI音频处理全流程加速指南

OpenVINO-Audacity插件:AI音频处理全流程加速指南 【免费下载链接】openvino-plugins-ai-audacity A set of AI-enabled effects, generators, and analyzers for Audacity. 项目地址: https://gitcode.com/gh_mirrors/op/openvino-plugins-ai-audacity Open…...

8.8 万赋能光伏新局!一网推助伍征新能源实现询盘零的突破

近日,江苏一网推网络技术有限公司(以下简称 “一网推”)与昆山伍征新能源有限公司(以下简称 “伍征新能源”)的百度爱采购代运营合作案例落地,成为光伏行业数字化转型的标杆。双方合作金额达 88700 元&…...

# 拍摄剪辑文案公司哪个技术强?专业视角解析行业标杆在数

拍摄剪辑文案公司哪个技术强?专业视角解析行业标杆在当今数字内容爆炸式增长的时代,优质视频内容已成为品牌营销的核心竞争力。"拍摄剪辑文案策划"的一站式服务模式,正在取代传统的分散作业方式,为各类企业提供更高效的…...

3分钟快速上手:res-downloader终极跨平台资源下载全攻略

3分钟快速上手:res-downloader终极跨平台资源下载全攻略 【免费下载链接】res-downloader 视频号、小程序、抖音、快手、小红书、直播流、m3u8、酷狗、QQ音乐等常见网络资源下载! 项目地址: https://gitcode.com/GitHub_Trending/re/res-downloader 还在为无…...

WeReader:革新微信读书体验的高效笔记管理工具

WeReader:革新微信读书体验的高效笔记管理工具 【免费下载链接】wereader 一个浏览器扩展:主要用于微信读书做笔记,对常使用 Markdown 做笔记的读者比较有帮助。 项目地址: https://gitcode.com/gh_mirrors/wer/wereader 你是否曾为微…...

微信聊天记录永久保存指南:数据备份与隐私保护全攻略

微信聊天记录永久保存指南:数据备份与隐私保护全攻略 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeChat…...

数据驱动的战斗优化:GBFR Logs全方位解析与实战指南

数据驱动的战斗优化:GBFR Logs全方位解析与实战指南 【免费下载链接】gbfr-logs GBFR Logs lets you track damage statistics with a nice overlay DPS meter for Granblue Fantasy: Relink. 项目地址: https://gitcode.com/gh_mirrors/gb/gbfr-logs 在《碧…...

Arduino Nano + A4988驱动42步进电机:从接线到代码的完整避坑指南

Arduino Nano与A4988驱动42步进电机实战指南 刚拿到Arduino Nano和A4988驱动板时,看着那些密密麻麻的引脚和电机线缆,不少初学者都会感到无从下手。步进电机控制看似简单,但实际搭建时总会遇到各种意想不到的问题——电机抖动不转、方向控制失…...

PLIC中断控制器深度解析:手把手实现RISCV多核中断调度(含设备树配置)

PLIC中断控制器深度解析:手把手实现RISCV多核中断调度(含设备树配置) 在物联网设备开发中,高效的中断处理机制往往是系统稳定性的关键。想象一下,当你设计的智能网关需要同时处理数十个传感器的数据流时,如…...

DNS协议详解:作用、完整解析过程(面试+考试必背版)

DNS协议详解:作用、完整解析过程(面试考试必背版)一、DNS 协议的作用主要功能二、DNS 核心基础知识三、DNS 完整解析过程(超清晰 8 步,面试必考)实验场景解析流程(标准递归迭代查询)…...

隐式神经表示在计算机视觉中的5个关键应用:图像超分辨率到3D场景重建

隐式神经表示在计算机视觉中的5个关键应用:图像超分辨率到3D场景重建 【免费下载链接】awesome-implicit-representations A curated list of resources on implicit neural representations. 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-implicit-repr…...

【郑州大学主办 | SPIE出版社出版,ISSNISBN双刊号出版 | 通信技术、计算机视觉与算法、嵌入式系统技术、机器人领域EI】2026年机器学习与嵌入式系统国际学术会议(MLES 2026)

MLES 2026会议已成功申请到SPIE出版社出版!ISSN&ISBN双刊号出版! 2026年机器学习与嵌入式系统国际学术会议(MLES 2026) 2026 International Conference on Machine Learning and Embedded Systems 2026年4月24-26日 &a…...

【WRF-Chem编译安装】使用集群系统环境编译安装WRF-Chem

目录 安装编译思路 编译错误记录 尝试编译器:Intel 尝试编译器:Gun 附录:完整自动化编译脚本 参考 安装编译思路 使用集群系统自带的 module 加载 MPI 和编译器: module avail # 查看可用的模块 module load compiler/intel # (举例) 加载编译器 module load mpi/open…...

如何快速构建本地AI应用:llama-cpp-python终极指南

如何快速构建本地AI应用:llama-cpp-python终极指南 【免费下载链接】llama-cpp-python Python bindings for llama.cpp 项目地址: https://gitcode.com/gh_mirrors/ll/llama-cpp-python 想要在本地运行大型语言模型而无需依赖云端服务吗?llama-cp…...

【海南大学主办 | 连续4届完成EI检索,见刊检索稳定!清华大学教授、国家杰青等学者出席报告】第五届电子信息工程、大数据与计算机技术国际学术会议 (EIBDCT 2026)

连续4届完成EI检索,见刊检索稳定!清华大学教授、国家杰青等学者出席报告! 第五届电子信息工程、大数据与计算机技术国际学术会议 (EIBDCT 2026) 2026 5th International Conference on Electronic Information Engineering, Big Data and C…...

Real-ESRGAN-GUI:终极AI图像增强工具,让模糊图片秒变高清

Real-ESRGAN-GUI:终极AI图像增强工具,让模糊图片秒变高清 【免费下载链接】Real-ESRGAN-GUI Lovely Real-ESRGAN / Real-CUGAN GUI Wrapper 项目地址: https://gitcode.com/gh_mirrors/re/Real-ESRGAN-GUI 在数字时代,我们每天都会接触…...

OBS-Multi-RTMP终极指南:5分钟实现多平台同步直播的完整解决方案

OBS-Multi-RTMP终极指南:5分钟实现多平台同步直播的完整解决方案 【免费下载链接】obs-multi-rtmp OBS複数サイト同時配信プラグイン 项目地址: https://gitcode.com/gh_mirrors/ob/obs-multi-rtmp OBS-Multi-RTMP是一款专为直播创作者设计的开源插件&#x…...

3个强力步骤:百度网盘插件让macOS用户突破下载限速

3个强力步骤:百度网盘插件让macOS用户突破下载限速 【免费下载链接】BaiduNetdiskPlugin-macOS For macOS.百度网盘 破解SVIP、下载速度限制~ 项目地址: https://gitcode.com/gh_mirrors/ba/BaiduNetdiskPlugin-macOS 副标题:如何在不升级会员的情…...

告别固定菜单!用YOLO-World实现‘看图说话’式物体检测,保姆级环境搭建与实战教程

告别固定菜单!用YOLO-World实现‘看图说话’式物体检测,保姆级环境搭建与实战教程 想象一下,你正在开发一款智能家居应用,需要识别用户随意描述的物品——比如"放在沙发左侧的无线充电器"或"窗台上那盆多肉植物&qu…...