[手撕数据结构]——堆总结

堆实现:

二叉树 - 我使用数组模拟实现的二叉树

大顶堆和小顶堆,小顶堆就是每一个父节点都比他的子节点的值大,故,根节点最大嘛

比较重要的公式:

计算父节点:(n - 1) / 2

计算子节点:左节点n * 2 + 1,右节点n * 2 + 2

面试必考方法:

初始堆的建立

java 复制代码
private void heapify(){
    // 遍历所有的非叶子节点
    for(int i = size / 2 - 1; i >= 0; i--){
        // 下潜
        down(i);
    }

}

上浮

java 复制代码
private void up(int offered){
    int child = size;
    // parent与offered作比较
    while(child > 0){
        int parent = (child - 1) / 2;
        if(offered > arr[parent]){
            arr[child] = arr[parent];
            child = parent;
        }else{
            break;
        }
    }
    arr[child] = offered;
}

下潜

java 复制代码
private void down(int p){
    int left = p * 2 + 1;
    int right = left + 1;
    int max = p;
    if(max < size && arr[left] > arr[max]){
        max = left;
    }
    if(max < size && arr[right] > arr[max]){
        max = right;
    }
    if(p != max){
        swap(p, max); // 交换两个节点
        down(max); // 递归调用
    }
}

应用场景

我就直接上力扣了:

  1. 合并K的有序数组
  2. 求数组第K大元素
  3. 求数据流第K大元素
  4. 求数据流中位数
相关推荐
深邃-1 小时前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
叼烟扛炮8 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
MegaDataFlowers12 小时前
206.反转链表
数据结构·链表
CN-Dust13 小时前
【C++】while语句例题专题
数据结构·c++·算法
xieliyu.15 小时前
Java手搓数据结构:从零模拟实现无头双向非循环链表
java·数据结构·链表
如何原谅奋力过但无声17 小时前
【灵神高频面试题合集01-03】相向双指针、滑动窗口
数据结构·python·算法·leetcode
jieyucx18 小时前
Go 数据结构入门:线性表、顺序表、链表
数据结构·链表·golang
阿维的博客日记18 小时前
zset为什么要用到skiplist+Dict的数据结构
数据结构·skiplist
编程之升级打怪19 小时前
KMP查询算法的匹配串的前缀后缀相同的最大长度
数据结构
没文化的阿浩21 小时前
【数据结构】排序(2)——直接选择排序、堆排序
数据结构·算法·排序算法