堆排序--C++实现

1. 简介

堆排序利用的是堆序性,最小堆进行从大到小的排序。

先建初堆,保证堆序性。将堆顶元素与最后一个元素交换,

就将当前堆中的最大(小)的元素放到了最后后。堆大小递减,再重新调整堆选出第二大,重复上述过程。

2. 实现

2.1 建初堆

由于堆具有递归性,即以根节点的所有子树都是一个堆。

我们需要从下往上调整堆。即从完全二叉树的最大非叶子节点开始调整堆,直到根节点。

这样才能保证堆序性。

对于数组3,4,1,2,5 ,建初堆的过程。

  • 代码
cpp 复制代码
template<typename T>
void adj_heap(std::vector<T> &arr,std::size_t rt, std::size_t bd) {

    T v = arr[rt];
    std::size_t child;
    std::size_t i;

    for (i = rt; i < bd; i = child) {

        child = i * 2 + 1;
        if ( child + 1 < bd && arr[child + 1] < arr[child])
            ++child;

        if (child >= bd || v <= arr[child] ) {
            break;
        }
        else{
            arr[i] = arr[child];
        }

    }

    arr[i] = v;
}


template<typename T>
void make_orig_heap(std::vector<T> &arr, std::size_t sz) {

    for (std::size_t i = sz/2 - 1; i != -1; --i){
        adj_heap(arr, i, sz);
    }
}
2.2 堆排序

建立初始堆后,我们就确定了最小(大)的元素。

将该元素与最后位置交换,并将堆大小 - 1。

我们就又得到了一个未调整的堆。我们重复调整堆和交换元素的过程,直到最后堆大小为1。

所以,最小堆进行排序形成的序列是从大到小。

过程如图

  • 代码
cpp 复制代码
template<typename T>
void heap_sort(std::vector<T> &arr, std::size_t sz) {

    if ( 0 == sz)
        return ;

    make_orig_heap(arr, sz);
    
    

    for (std::size_t i = sz - 1; i > 0; --i) {
        T last = arr[i];
        arr[i] = arr[0];
        arr[0] = last;
        adj_heap(arr, 0, i);
    }

}
相关推荐
我是菜鸟0713号20 分钟前
Qt 中 OPC UA 通讯实战
开发语言·qt
JCBP_22 分钟前
QT(4)
开发语言·汇编·c++·qt·算法
Brookty26 分钟前
【JavaEE】线程安全-内存可见性、指令全排序
java·开发语言·后端·java-ee·线程安全·内存可见性·指令重排序
百锦再40 分钟前
[特殊字符] Python在CentOS系统执行深度指南
开发语言·python·plotly·django·centos·virtualenv·pygame
Anson Jiang40 分钟前
浏览器标签页管理:使用chrome.tabs API实现新建、切换、抓取内容——Chrome插件开发从入门到精通系列教程06
开发语言·前端·javascript·chrome·ecmascript·chrome devtools·chrome插件
会开花的二叉树1 小时前
继承与组合:C++面向对象的核心
java·开发语言·c++
潮汐退涨月冷风霜2 小时前
数字图像处理(1)OpenCV C++ & Opencv Python显示图像和视频
c++·python·opencv
长河3 小时前
Java开发者LLM实战——LangChain4j最新版教学知识库实战
java·开发语言
第七序章3 小时前
【C++STL】list的详细用法和底层实现
c语言·c++·自然语言处理·list
Cyan_RA93 小时前
SpringMVC @RequestMapping的使用演示和细节 详解
java·开发语言·后端·spring·mvc·ssm·springmvc