算法之排序

一 堆排序

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(整数除法)。
相关推荐
玫瑰花店1 天前
万字C++中锁机制和内存序详解
开发语言·c++·算法
Elias不吃糖1 天前
LeetCode每日一练(209, 167)
数据结构·c++·算法·leetcode
铁手飞鹰1 天前
单链表(C语言,手撕)
数据结构·c++·算法·c·单链表
悦悦子a啊1 天前
项目案例作业(选做):使用文件改造已有信息系统
java·开发语言·算法
小殊小殊1 天前
【论文笔记】知识蒸馏的全面综述
人工智能·算法·机器学习
无限进步_1 天前
C语言动态内存管理:掌握malloc、calloc、realloc和free的实战应用
c语言·开发语言·c++·git·算法·github·visual studio
im_AMBER1 天前
AI井字棋项目开发笔记
前端·笔记·学习·算法
Wadli1 天前
项目2 |内存池1|基于哈希桶的多种定长内存池
算法
TT哇1 天前
【BFS 解决拓扑排序】3. ⽕星词典(hard)
redis·算法·宽度优先
橘颂TA1 天前
【剑斩OFFER】算法的暴力美学——判定字符是否唯一
算法·c/c++·结构与算法