堆排序算法流程
将待排序序列构造成一个大顶堆,此时,整个序列的最大值就是堆顶的根节点。将其与末尾元素进行交换,此时末尾就为最大值。然后将剩余n-1个元素重新构造成一个堆,这样会得到n个元素的次小值。如此反复执行,便能得到一个有序序列了
大顶堆:arr[i] >= arr[2i+1] && arr[i] >= arr[2i+2]
小顶堆:arr[i] <= arr[2i+1] && arr[i] <= arr[2i+2]
用golang实现
func HeapSort(intList []int) {
end := len(intList) - 1
for end >= 0{
heap(intList, end)
intList[0], intList[end] = intList[end], intList[0]
end--
}
}
func heap(intList []int, end int) {
i := end
// 判断end是否是奇数
if end%2 == 1 {
// 比较end和其父亲的大小
if intList[end] > intList[(end-1)/2] {
// 和父亲交换位置
intList[end], intList[(end-1)/2] = intList[(end-1)/2], intList[end]
}
i = end - 1
}
for ; i > 0; i -= 2 {
// 判断孩子和父亲的大小
father := intList[(i-2)/2]
leftChild := intList[i-1]
rightChild := intList[i]
maxIndex := i // 两个孩子中大的一个的下标
if leftChild > rightChild{
maxIndex = i-1
}
if father < intList[maxIndex] {
intList[(i-2)/2], intList[maxIndex] = intList[maxIndex], intList[(i-2)/2]
}
}
}