漫画:什么是堆排序算法?
创始人
2025-05-30 02:28:06
0

面试官:写一个堆排吧

堆排是基于堆的一种排序算法,对于堆的了解,请看可以管理时间的二叉堆(如果对堆的插入和删除不清楚,强烈建议先看堆),今天我们聊聊堆排的思想,复杂度以及稳定性

一、堆排思想

前情回顾:慧能给一尘解决了时间管理上的问题[可以管理时间的二叉堆]https://www.iamshuaidi.com/586.html)

过了几天后,一尘高兴地跑到老师跟前

image-20230211234328478

image-20230211234343556

早知不来了,一尘心想

image-20230211234407848

image-20230211234424939

一尘心想:上次去溪边游玩不是已经出过这个题吗,当时学会了冒泡排序,这次肯定不是那么简单,肯定和前几天的堆有关系

image-20230211234440616

image-20230211234453065

image-20230211234506234

一尘:如果将这个数组调整为小根堆,那么根据小根堆堆顶一直是最小元素的特性,我可以不断地取(删除)堆顶的元素,直到堆中只剩下一个元素,这样就可以得到一个递减的元素序列了

删除中交换操作会破坏堆有序,但下沉操作会重新调整堆

一尘画了一个图解释道

image-20230211234524089

image-20230211235017970

image-20230211235032200

image-20230211235045565

这样一直删除到只有一个元素的时候,整个数组就排好序了

删除包括三个步骤:

① 交换堆顶与堆最后一个元素

② 堆大小(heapSize)减一

③ 调整堆(sink(arr,1))

具体讲解请看:二叉堆

image-20230211235100734

二、建堆

image-20230211235115053

上浮(swim)操作会保持堆有序

image-20230211235141096

图片

image-20230211235354169

image-20230211235608911

image-20230211235625241

image-20230211235637321

image-20230211235715873

image-20230211235730624

慧能:每个叶子节点可以视为一个大小为一的堆,我们可以自底向上从非叶子节点开始每层从右至左给每个节点都调用下沉(sink)方法,这样以当前节点为根节点的树就变为堆了

image-20230211235745028

image-20230211235832024

image-20230211235843665

image-20230211235858078

image-20230211235913190

image-20230211235931270

image-20230212000032067

注意:在下沉(sink)某个节点的时候,这个节点的两个孩子必须是堆

三、堆排序代码

image-20230212000050676

image-20230212000105644

image-20230212000229139

又要写代码,一尘心想,虽说心中这样想,但还是要写的,思考了一会,只见一尘写下了如下代码

image-20230212222709250

这里的 heapSize/2 就是第一个非叶子节点的下标

image-20230212222734390

过了一会一尘又写出了删除最小值的代码

image-20230212222749952

image-20230212222805675

前两个都写出来了,剩下的排序就很简单了,按照之前的思路,先建立一个小根堆,然后不断地删除堆顶最小元素,删除N-1次就OK了

image-20230212222824770

image-20230212222838137

image-20230212222855095

一尘暗自惊叹老师的功力,不知不觉又学到了一个排序方法

四、时间复杂度

image-20230212222910716

看到数学头疼的可以直接跳过看结论

一尘还没缓过神,又来了一个最让他头疼的时间复杂度

image-20230212222929612

image-20230212222946087

慧能拿出了笔和纸

慧能:你想一下堆排的整个过程,第一步建堆,第二步执行N-1次deleteMin()方法,最后取两者复杂度较高的就行了

五、建堆时间复杂度

建堆的时候时间消耗在下沉操作上,而下沉操作最多下沉到底,显然,高度为h的节点下沉代价为O(h)

image-20230212223001122

堆中所有元素下沉代价之和就是建堆的代价(时间复杂度)

叶子节点高度为0,下沉代价为0

把堆中不同高度中的所有节点相加起来就是全部的节点

所以问题变为:

① 高度最高多高(高度上界)

② 高度h有多少节点

这里你记住两个结论

image-20230212223016055

有兴趣的可以证证这两个结论

这里我们把不同高度的每个节点执行sink所需要的代价累加起来

image-20230212223029985

image-20230212223058312

image-20230212223118242

image-20230212223131695

一尘长舒一口气

六、N-1次删除复杂度

image-20230212223146024

n-1次调用deleteMin

deleteMin中包含 swap操作和 sink操作

swap操作代价为常数,sink操作代价为lgn, swap操作相对于sink操作可以忽略不计

则相当于进行了n-1次sink操作

则一共花费的代价为:(n-1)*lgn ~ nlgn

时间复杂度为O(nlgn)

image-20230212223513491

image-20230212223539054

image-20230212223552692

七、稳定性

image-20230212223606487

image-20230212223620574

一尘说着说着画了一个图

image-20230212223632931

image-20230212223702609

image-20230212223718628

初始状态的5的先后顺序和排完序的顺序明显不一样了(黄色5跑到红色5左边去了),所以这个排序不是稳定的

image-20230212223735301

本图片是一个尾部占位符

更多排序算法文章

1. 漫画:什么是冒泡排序算法?

2. 漫画:什么是选择排序算法?

3. 漫画:什么是插入排序算法?

4. 漫画:什么是希尔排序算法?

5. 漫画:什么是归并排序算法?

6. 漫画:什么是快速排序算法?

7. 漫画:什么是堆排序算法?

8. 漫画:什么是基数排序算法?

9. 漫画:什么是外部排序?

10. 什么是计数排序?

11. 十大排序算法极简汇总篇

推荐阅读

下载破 2w+,在校生必看,《程序员内功修炼》第二版出炉

从双非到大厂,帅地写了一本原创PDF送给大家

一个帮你拿offer的校招网站

算法刷题路线(系统+全面)

作者简介:我是帅地,校招拿到过不少大厂offer,毕业去了腾讯研发岗,毕业半年整到人生第一个 100 万,目前专注于写大学规划 + 校招求职相关的内容,著有个人原创网站 PlayOffer。

相关内容

热门资讯

银行、消金公司助贷余额增速不得... 近日,中国证券报记者从多位业内人士处独家获悉,5月以来,多地金融监管部门对部分中小银行、消金公司下达...
朱鸿接任陈航,担任钉钉科技有限... 消费日报-今朝新闻讯 天眼查显示,6月23日,钉钉科技有限公司发生工商变更,陈航卸任法定代表人、董事...
3日累跌超20%,德创环保:公... 6月25日, 德创环保(603177.SH)公告,公司股票于2026年6月23日、6月24日和6月2...
北京发布2026年第七轮拟供商... 央广网北京6月25日消息(记者门庭婷)6月25日,北京市规划和自然资源委员会网站发布了2026年第七...
开放麦 | 启明创投胡奇:从A... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
腾讯孙忠怀:在行业转身处 6月24日,2026腾讯视频年度发布在上海举行。腾讯公司副总裁、腾讯在线视频董事长孙忠怀以《在行业转...
加息,突变!美联储,重磅传来!... 美联储政策路径突生变数。 美国商务部经济分析局最新公布的数据显示,5月个人消费支出(PCE)物价指数...
6月合肥上门收金必看!5步避坑... 2026年6月,合肥黄金市场持续高位运行,不少市民翻出家里闲置的旧金饰、投资金条想变现,上门回收因为...
潮汕女富豪挂帅后加码液冷!祥鑫... 潮汕女强人,带着百亿公司加码液冷散热。 6月24日晚间,祥鑫科技(002965.SZ)公告称,公司董...
马斯克向太空要电,GobiX ... 一场关于「去哪里找电」的全球竞赛,正在朝两个方向展开。 作者|周永亮 编辑| 郑玄 「太空光伏是不是...
原料药行业陷入周期低谷 有药企... 每经记者|许立波 每经编辑|魏文艺 “过完年到现在,我们整个团队每个月都在出差,跑遍了亚非拉、欧美市...
家门口筛查白内障!永顺泽家镇暖... 大众卫生报·新湖南客户端6月25日讯(通讯员 彭雪姣)为切实解决辖区老年性白内障患者异地就医奔波、就...
终于等到!油价马上再大跌,这个... 点击添加图片描述(最多60个字) 编辑 各位车主朋友,好消息接二连三! 继6月18日油价大幅下调...
丈量出海新路 世界酒庄影响力指... 长期以来,全球酒庄评价体系由西方机构主导,且大多局限于单一酒种、单一评价维度,这一局面正逐渐被打破。...
峰瑞资本创始合伙人李丰:从资本... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
原创 A... 迈向成熟,还有茁壮成长的机会。 作者 | 方璐 编辑丨于婞 来源 | 野马财经 2026年6月21日...
为企业解锁出海新通道!亚太中小... 6月24日下午,作为2026年APEC中小企业工商论坛的重要组成部分,亚太中小企业国际化合作发展论坛...
君赛生物港股IPO,增聘兴证国... 跟丰宜科技一样,正冲刺港股IPO的上海君赛生物股份有限公司(简称“君赛生物”)增聘一位整体协调人。 ...
圣邦股份明日上市:暗盘涨24%... 雷递网 雷建平 6月25日 圣邦微电子(北京)股份有限公司(简称:“圣邦股份”,股票代码:“0366...
科技“吃肉”,券商跟着“喝汤”... 当科技持续成为市场核心主线,押中硬科技项目的券商也成为被追逐的焦点。 6月24日,半导体零部件概念股...