堆排序——向下调整

之前我们要想实现堆排序,是运用建堆代码来实现的:
向上调整建堆——向下调整排序
堆排序——向下调整_第1张图片
那么去我们可不可以只适用一种调整方法(向下调整)就能实现这样的功能呢?

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

堆排序——向下调整_第2张图片
堆排序——向下调整_第3张图片
总结,把一个树,拆分成单个单个的树,然后向下调整,把他们都变成堆,最后整个树就成了堆

向上调整,向下调整代码总结:
堆排序——向下调整_第4张图片
向下调整
堆排序——向下调整_第5张图片
可以看出向上调整的时间复杂度是:N*logN
向下调整的时间复杂度为:N

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

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

补充:树的一个做题性质
在一个树中,节点为0的节点数,是节点为2的节点数+1:n0=n2+1
在一个完全二叉树中节点为1的节点数最多只会有一个
例题:
堆排序——向下调整_第6张图片

你可能感兴趣的:(数据结构)