堆树的定义:

(1)堆树是一颗完全二叉树;

(2)堆树中某个节点的值总是不大于或不小于其孩子节点的值;

(3)堆树中每个节点的子树都是堆树。

当父节点的键值总是大于或等于任何一个子节点的键值时为最大堆。 当父节点的键值总是小于或等于任何一个子节点的键值时为最小堆。如下图所示,左边为最小堆,右边为最大堆。

最小堆建立和堆排序最小堆建立和堆排序

 

数组与堆

无序数组转化成原始的二叉堆:

4 5 3 2 6 1

最小堆建立和堆排序

 

构建最小堆:

元素下沉思想:从无序数组的最后往前遍历,堆树从下层到上层依次搭建完成

1 从叶子节点(无序数组的最后一个元素)出发,把当前的parent设置为无序数组中的最后一个数(也就是叶子节点),依次往前遍历,当parent是叶子节点,就不做操作

2 当parent遍历到非叶子节点,此时,它就有左子节点和右子节点或者只有左子节点。需要做的操作:先在左右子节点中找到最小元素所在的索引,然后将左右子节点中的最小元素与parent的节点,进行比较,如果小于,则交换,同时更新parent和child的位置。否则不交换,退出当前循环。

3 “元素下沉”的终止条件就是父节点的元素值不小于其任意左右子节点的元素值,或者当前父节点无子节点(即当前节点为叶子节点)。

def heap_min(heap):
    for parent in range(len(heap)-1,-1,-1):
        child = 2*parent+1
        while child <len(heap):
            if child+1<len(heap) and heap[child+1]<heap[child]:
                child += 1
            if heap[parent]<= heap[child]:
                break
            heap[parent],heap[child] = heap[child],heap[parent]
            parent,child = child,2*child+1
    return heap
    
    
print(heap_min([4,5,3,2,6,1]))

输出结果是:构建了最小堆

最小堆建立和堆排序

堆排序:

是指利用堆(最大堆、最小堆)这种数据结构所设计的一种排序算法。堆是一个完全二叉树的结构,并同时满足如下性质:即子结点的键值或索引总是小于(或者大于)它的父节点。

相关文章: