算法之排序

一 堆排序

1.1 堆概念

(4 封私信) 【算法】排序算法之堆排序 - 知乎

1.1.1 堆的存储

一般用数组来表示堆,下标为 i 的结点的父结点下标为(i-1)/2;其左右子结点分别为 (2i + 1)、(2i + 2)

1.1.2 最大堆的构建

cpp 复制代码
void buildMaxHeap(vector<int>& nums, int len) {
    for (int i = len / 2; i >= 0; --i) {
        maxHeapify(nums, i, len);
    }
}

功能解析:

  • 作用:将整个数组转换为最大堆。
  • 实现逻辑:
    1. 最后一个非叶子节点开始,向前遍历到根节点(索引 0)。
    2. 对每个节点调用maxHeapify进行堆化。
  • 为什么从len/2开始?
    • 完全二叉树中,索引> len/2的节点都是叶子节点(没有子节点),无需堆化。
    • 最后一个非叶子节点的索引为len/2(整数除法)。
相关推荐
小魏每天都学习18 小时前
【算法——c/c++]
c语言·c++·算法
智码未来学堂19 小时前
探秘 C 语言算法之枚举:解锁解题新思路
c语言·数据结构·算法
Halo_tjn19 小时前
基于封装的专项 知识点
java·前端·python·算法
春日见19 小时前
如何避免代码冲突,拉取分支
linux·人工智能·算法·机器学习·自动驾驶
副露のmagic19 小时前
更弱智的算法学习 day59
算法
u01092727120 小时前
C++中的RAII技术深入
开发语言·c++·算法
2401_8321319521 小时前
模板错误消息优化
开发语言·c++·算法
金枪不摆鳍21 小时前
算法--二叉搜索树
数据结构·c++·算法
近津薪荼21 小时前
优选算法——双指针6(单调性)
c++·学习·算法
helloworldandy21 小时前
高性能图像处理库
开发语言·c++·算法