堆排序——向下调整

之前我们要想实现堆排序,是运用建堆代码来实现的:

向上调整建堆------向下调整排序

那么去我们可不可以只适用一种调整方法(向下调整)就能实现这样的功能呢?

向要只使用向下调整就实现堆排序

首先就是把数组里的值使用向下调整就变成堆,但是想要使用向下调整,应该出了根之外其他都满足堆才行

向下调整建堆------向下调整排序


总结,把一个树,拆分成单个单个的树,然后向下调整,把他们都变成堆,最后整个树就成了堆

向上调整,向下调整代码总结:

向下调整

可以看出向上调整的时间复杂度是:N*logN

向下调整的时间复杂度为:N

想要在一个文件中有一亿个数据中找最大的前100个数据

1,从文件中读取100个数据,建立小堆

2、在依次读取文件中剩余的数据,于堆顶数据比较,只要比堆顶大就替换,然后再向下调整,这样把所有剩余的数于堆顶数据比较完后,堆里的数据就是最大的前100个数

补充:树的一个做题性质

在一个树中,节点为0的节点数,是节点为2的节点数+1:n0=n2+1

在一个完全二叉树中节点为1的节点数最多只会有一个

例题:

相关推荐
I_LPL5 小时前
hot100贪心专题
数据结构·算法·leetcode·贪心
m0_672703318 小时前
上机练习第51天
数据结构·c++·算法
仰泳的熊猫9 小时前
题目2577:蓝桥杯2020年第十一届省赛真题-走方格
数据结构·c++·算法·蓝桥杯
灰色小旋风10 小时前
力扣13 罗马数字转整数
数据结构·c++·算法·leetcode
ccLianLian11 小时前
数论·欧拉函数
数据结构·算法
会编程的土豆12 小时前
C++中的 lower_bound 和 upper_bound:一篇讲清楚
java·数据结构·算法
HUTAC12 小时前
关于进制转换及其应用的算法题总结
数据结构·c++·算法
XW010599912 小时前
6-函数-1 使用函数求特殊a串数列和
数据结构·python·算法
沉鱼.4413 小时前
枚举问题集
java·数据结构·算法
罗超驿13 小时前
Java数据结构_栈_算法题
java·数据结构·