/**
* 维护最大堆的性质
*/
func heapify(inout A:[Int], i:Int, size:Int) {
var l = 2 * i
var r = l + 1
var largest = i
if l < size && A[l] > A[i] {
largest = l
}
if r < size && A[r] > A[largest] {
largest = r
}
if largest != i {
swap(&A, i, largest)
heapify(&A, largest, size)
}
}
/**
* 构建最大堆
*/
func buildHeap(inout A:[Int]) {
for var i = A.count/2; i >= 0; i-- {
heapify(&A, i, A.count)
}
println("build heap:\(A)")
}
/**
*堆排序
*/
func heapSort(inout A:[Int]) {
buildHeap(&A)
var size = A.count
for var i = A.count - 1; i >= 1; i-- {
swap(&A, i, 0)
size--
heapify(&A, 0, size)
}
println("sorted heap:\(A)")
}
var A = [4, 1, 3, 2, 16, 9,9, 10, 14, 8, 7] heapSort(&A) avens-MacBook-Pro:aven$ ./max-heap-sort.swift build heap:[16, 14, 9, 10, 8, 7, 9, 2, 3, 1, 4] sorted heap:[1, 2, 3, 4, 7, 8, 9, 9, 10, 14, 16]
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有