数据结构|堆

1. 堆的概念

把元素集合 k = {k0, k1, k2, …, kn-1} 按完全二叉树的顺序存储在一个一维数组中,并满足:
ki <= k2i + 1 且 ki <= k2i + 2(ki >= k2i + 1 且 ki >= k2i + 2)i = 0, 1, 2, 3…,则称为小堆(或大堆)。
将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做最小堆或小根堆。
堆的性质:

  • 堆中某个节点的值总是不大于或者不小于其父节点的值;
  • 堆总是一颗完全二叉树。

大根堆
在这里插入图片描述
小根堆
小根堆

2. 堆的创建

2.1 堆向下调整

前提:除了要调整的位置之外,其余的数据以满足堆的性质。

public static void shiftDown(long[] array, int size, int index){
    while (true){
        int leftIndex = 2 * index + 1;
        if (leftIndex >= size){
            return;
        }

        int rightIndex = leftIndex + 1;
        int minIndex = leftIndex;
        if (rightIndex < size && array[rightIndex] < array[leftIndex]){
            minIndex = rightIndex;
        }

        if (array[index] <= array[minIndex]){
            return;
        }

        long t = array[index];
        array[index] = array[minIndex];
        array[minIndex] = t;

        index = minIndex;
    }
}

2.2 堆的创建

public static void creatHeap(long[] array, int size){
    // 找到第一个非叶子节点,从该节点位置开始往前一直到根节点,遇到一个节点,应用向下调整
    for (int i = (size - 2) / 2; i >= 0; i--){
        shiftDown(array, size, i);
    }
}

2.3 堆的插入

  1. 将元素放入到底层空间;
  2. 将最后新插入的结点向上调整,知道满足堆的性质。
public static void shiftUp(long[] array, int index){
    while (index > 0){
        int parent = (index -  1) / 2;
        
        if (array[parent] < array[index]){
            return;
        }else {
            // 将双亲与孩子节点进行交换
            long t = array[index];
            array[index] = array[parent];
            array[parent] = t;
            
            index = parent;
            parent = (parent - 1) / 2;
        }
    }
}

2.4 堆的删除

  1. 将堆顶元素和堆中最后一个元素交换
  2. 将堆中有效数据个数减少一个
  3. 对堆顶元素进行向下调整。

3. 堆的应用

  1. 用堆作为底层结构封装优先级队列
  2. 堆排序
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值