作者: 我有一只碗 | 来源:发表于2018-02-10 11:39 被阅读0次

二叉堆是一棵满二叉树,父节点的值大于子节点。

用数组存储二叉堆,假如一个节点的下标为k,那么这个节点的左孩子就是2k,右孩子就是2k+1。

用Go语言实现如下:

package heap

import (
    "fmt"
)

// MaxHeap 大顶堆
type MaxHeap struct {
    data []int
}

// Init 初始化
func (heap *MaxHeap) Init(maxSize int) {
    heap.data = make([]int, 0, maxSize)
    heap.data = append(heap.data, 0)
}

// Size 堆的长度
func (heap MaxHeap) Size() (size int) {
    size = len(heap.data) - 1
    return
}

// IsEmpty 堆是否为空
func (heap MaxHeap) IsEmpty() bool {
    return heap.Size() == 0
}

// Insert 插入一个元素
func (heap *MaxHeap) Insert(item int) {
    heap.data = append(heap.data, item)
    heap.shiftUp(heap.Size())
}

// Extract 删除一个元素
func (heap *MaxHeap) Extract() int {
    item := heap.data[1]
    heap.data[1], heap.data[heap.Size()] = heap.data[heap.Size()], heap.data[1]
    heap.data = heap.data[:len(heap.data)-1]
    if !heap.IsEmpty() {
        heap.shiftDown(1)
    }
    return item
}

// shiftUp 向上调整堆的结构
// 优化:不用每次都交换
func (heap *MaxHeap) shiftUp(k int) {
    temp := heap.data[k]
    for k > 1 && heap.data[k/2] < temp {
        heap.data[k/2] = heap.data[k]
        k /= 2
    }
    heap.data[k] = temp
}

// shiftDown 向下调整堆的结构
// 优化:不用每次都交换
func (heap *MaxHeap) shiftDown(k int) {
    temp := heap.data[k]
    for k*2 <= heap.Size() {
        j := 2 * k
        if j+1 <= heap.Size() && heap.data[j+1] > heap.data[j] {
            j = j + 1
        }
        if temp >= heap.data[j] {
            break
        }
        heap.data[k] = heap.data[j]
        k = j
    }
    heap.data[k] = temp
}

// Show 显示堆的内容
func (heap MaxHeap) Show() {
    for i, e := range heap.data {
        if i == 0 {
            continue
        } else {
            fmt.Println(e)
        }
    }
}

相关文章

  • 堆 - 堆的应用

    堆有三个典型的应用场景:实现优先队列、求 Top K 、求中位数 实现优先队列 优先队列:队列的性质是先进先出,但...

  • 二叉堆是一棵满二叉树,父节点的值大于子节点。 用数组存储二叉堆,假如一个节点的下标为k,那么这个节点的左孩子就是2...

  • 应用: 排序,从小到大用最大堆,从大到小用最小堆 选出元素中的 top k 个top k 个最小数:数组前k个元素...

  • 完全二叉树 二叉堆 二叉堆有最大堆和最小堆的区别,最大堆只保证每个节点的父节点大于当前节点,但不保证上一层节点的值...

  • 堆的定义: n个元素序列{k1,k2,...,ki,...,kn},当且仅当满足下列关系时称之为堆: (ki...

  • http://bubkoo.com/2014/01/14/sort-algorithm/heap-sort/ 1 ...

  • 堆 …

    南山南,北山北,南山有谷堆,北山有花蕾,山坡下,大道中,野树停在石堆,秋风送,冷雪飘,旅途空旷叶儿飞,时间漫,皱纹...

  • 题目:100w个数中找出最大的100个。 维护一个100个元素的小根堆即可。 或者直接维护一个用来存储当前最大的1...

网友评论

      本文标题:

      本文链接:https://www.haomeiwen.com/subject/tcyftftx.html