【leetcode】排序算法总结

第 11 章 排序 - Hello 算法动画图解、一键运行的数据结构与算法教程https://www.hello-algo.com/chapter_sorting/

堆排序

cpp 复制代码
#include <iostream>
#include <vector>

using namespace std;

/* 堆的长度为 len ,从节点 i 开始,从顶至底堆化 */
void heapfy(vector<int>& nums, int len, int i) {
    while (true) {
        // 判断节点 i, l, r 中值最大的节点,记为 max
        int left = 2 * i + 1;
        int right = 2 * i + 2;
        int max = i;
        if (left < len && nums[left] > nums[max]) {
            max = left;
        }
        if (right < len && nums[right] > nums[max]) {
            max = right;
        }
        // 若节点 i 最大或索引 l, r 越界,则无须继续堆化,跳出
        if (max == i) {
            break;
        }
        // 交换两节点
        swap(nums[i], nums[max]);
        // 循环向下堆化
        i = max;
    }
}

/* 堆排序 */
void heapSort(vector<int>& nums) {
    int len = nums.size();

    // 建堆操作:堆化除叶节点以外的其他所有节点
    for (int i = len / 2 - 1; i >= 0; --i) {
        heapfy(nums, len, i);
    }
    // 从堆中提取最大元素,循环 n-1 轮
    for (int i = len - 1; i > 0; --i) {
        // 交换根节点与最右叶节点(交换首元素与尾元素)
        swap(nums[i], nums[0]);
        // 以根节点为起点,从顶至底进行堆化
        heapfy(nums, i, 0);
    }
}

int main() {
    vector<int> nums = {5, 2, 4, 6, 8, 1};
    heapSort(nums);
    for (auto& num : nums) {
        cout << num << endl;
    }
}
相关推荐
小O的算法实验室5 分钟前
2024年ESWA SCI1区TOP,容错文化概率粒子群算法+多 AGV 路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
WW_千谷山4_sch39 分钟前
洛谷P1120&UVA307 [CERC 1995] 小木棍
c++·算法·深度优先
XLYcmy1 小时前
高级密码猜测生成器AdvancedPasswordGenerator密码生成器程序详细分析
开发语言·python·算法·网络安全·开发工具·源代码·口令安全
im_AMBER2 小时前
Leetcode 93 找出临界点之间的最小和最大距离
c++·笔记·学习·算法·leetcode
有一个好名字3 小时前
力扣:除自身以外数组的乘积
java·算法·leetcode
bkspiderx3 小时前
C++中的访问控制:private、public与protected的深度解析
开发语言·c++·算法·访问控制·private·public·protected
ullio4 小时前
arc207c - Combine to Make Non-decreasing
算法
ZhuNian的学习乐园4 小时前
LLM对齐核心:RLHF 从基础到实践全解析
人工智能·python·算法
iAkuya4 小时前
(leetcode)力扣100 31K个一组翻转链表(模拟)
算法·leetcode·链表
铭哥的编程日记5 小时前
二叉树遍历的递归和非递归版本(所有题型)
算法