堆排序golang实现

package main

import "fmt"

// 堆排序
//算法导论chapter 6

func left(i int) int {
	return  2*i
}
func right(i int) int {
	return 2*i+1
}

// 维护最大堆性质
func maxHeapify(arr []int, i int, heapSize int) {
	l := left(i)
	r := right(i)
	var largest int
	if l < heapSize && arr[l]>arr[i] {
		largest = l
	} else {
		largest = i
	}
	if r < heapSize && arr[r]>arr[largest] {
		largest = r
	}

	if largest != i {
		arr[i], arr[largest] = arr[largest], arr[i]
		maxHeapify(arr, largest, heapSize)
	}

}

//建堆
func buildMaxHeap(arr []int, heapSize int) {

	for i := len(arr)/2; i >= 0; i-- {
		maxHeapify(arr,i, heapSize)
	}
}


//堆排序
func heapSort(arr []int) {
	var heapSize = len(arr)
	buildMaxHeap(arr, heapSize)
	for i := len(arr)-1; i >= 1; i-- {
		arr[0], arr[i] = arr[i], arr[0]
		heapSize--
		maxHeapify(arr, 0, heapSize)
	}


}


func main() {
	arr := []int {0,9,2,1,3,8,4,5,7,6}
	heapSort(arr)
	fmt.Print(arr)

}




 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值