Python 堆排序
堆排序(Heapsort)是指利用堆这种数据结构所设计的一种排序算法。堆积是一个近似完全二叉树的结构,并同时满足堆积的性质:即子结点的键值或索引总是小于(或者大于)它的父节点。堆排序可以说是一种利用堆的概念来排序的选择排序。
实例
def heapify(arr, n, i):
largest = i
l = 2 * i + 1 # left = 2*i + 1
r = 2 * i + 2 # right = 2*i + 2
if l < n and arr[i] < arr[l]:
largest = l
if r < n and arr[largest] < arr[r]:
largest = r
if largest != i:
arr[i],arr[largest] = arr[largest],arr[i] # 交换
heapify(arr, n, largest)
def heapSort(arr):
n = len(arr)
# Build a maxheap.
for i in range(n, -1, -1):
heapify(arr, n, i)
# 一个个交换元素
for i in range(n-1, 0, -1):
arr[i], arr[0] = arr[0], arr[i] # 交换
heapify(arr, i, 0)
arr = [ 12, 11, 13, 5, 6, 7]
heapSort(arr)
n = len(arr)
print ("排序后")
for i in range(n):
print ("%d" %arr[i]),
执行以上代码输出结果为:
排序后 5 6 7 11 12 13
heuwst
674***591@qq.com
改进参考代码:
1、迭代堆化
2、迭代的两种写法
heuwst
674***591@qq.com
小白
673***253@qq.com
堆排序有点像先二分法找极大值,再冒泡排序:
小白
673***253@qq.com
noname
ZHK***11@163.com
上面那个就不算堆排序,感觉是强行弄个什么根节点出来,稍微改下有点像归并排序,只不过归并排序是给子序列排序,而这个是每轮循环找出最大值
noname
ZHK***11@163.com
hhhhhh
242***9851@qq.com
作为一个菜鸟,感觉源代码的注释写得太少了,以下做点注解吧。
关键有3个点:
1、先把堆调成小根堆的状态,方法是在每个结点的所有根部中确定它的位置;
2、heapify函数实际上是对传入的arr[i]点在其所有根部中确定它的位置;
3、堆头与堆尾交换,此后堆尾退出堆,堆的范围缩小1,公式中i即为堆的长度,之后再将新到堆首的点放在合适的位置,因为其他点均已在正确的位置上,其他点最多与新点交换一次。
hhhhhh
242***9851@qq.com