二叉堆

作者: senzx | 来源:发表于2021-04-23 23:33 被阅读0次

二插堆的性质

image.png

完全二叉树的节点数量为n,节点编号为[0,n-1],则:

  1. 节点i的父节点是 floor((i-1)/2)
  2. 节点i的左子节点是2i+1,左子节点是2i+2
  3. 则最后一个非叶子节点的编号为floor(n/2)-1

批量建堆

参考恋上数据结构与算法

public class Solution {
    public static void main(String[] args) {
        Solution obj = new Solution();
        int[] nums = {30,34,73,60,68,43};
        obj.buildMaxHeap(nums);

    }

    public void buildMaxHeap(int[] nums){
        int n = nums.length;
        //自下而上的下滤
//        for(int i=n/2-1;i>=0;i--){
//            siftDown(nums, i);
//        }
        //自上而下的上滤
        for(int i=1;i<n;i++){
            siftUp(nums, i);
        }
    }

    public void siftUp(int[] nums, int index){
        int n = nums.length;
        int element = nums[index];

        while(index > 0){
            int parentIdx = (index-1)/2;
            int parent = nums[parentIdx];
            if(parent<element){
                nums[index] = parent;
                index = parentIdx;
            }else{
                break;
            }
        }
        nums[index] = element;
    }

    public void siftDown(int[] nums, int index){
        int n = nums.length;
        int element = nums[index];

        while(2*index+1<n){
            int childIdx = 2*index+1;
            int child = nums[childIdx];
            if(2*index+2<n){
                int rightIdx = 2*index+2;
                int right = nums[rightIdx];
                if(right>child){
                    child=right;
                    childIdx=rightIdx;
                }
            }
            if(child>element){
                nums[index] = child;
                index = childIdx;
            }else{
                break;
            }
        }
        nums[index] = element;
    }
}

添加

新节点添加在最后,然后对这个节点做上滤。

删除

二叉堆只能删除第一个节点(下标为0的节点),把最后一个节点移到第一个节点的位置,然后对第一个节点做下滤。

相关文章

  • 用go实现二叉堆插入删除构建

    二叉堆的插入: 二叉堆的删除: 二叉堆的构建:

  • [数据结构与算法-iOS 实现]二叉堆原理实现及top k 问题

    二叉堆 demo 二叉堆其实就是一颗完全二叉树,所以又可以叫做完全二叉堆 二叉堆的底层可以用数组来实现 对于二叉堆...

  • 二叉堆

    二叉堆定义 二叉堆是一种特殊的堆, 二叉堆是完全二叉树或者近似完全二叉树. 二叉堆满足堆特性: 父节点的键值总是保...

  • 二叉堆(Binary Heap)

    二叉堆这个数据结构有点意思,自己做了个总结,内容结构如下: 二叉堆性质 二叉堆操作 应用 二叉堆性质: 堆(Hea...

  • 堆排序(下):最大堆

    二叉堆,简称堆 Heap 尖的完全二叉树。也有三叉堆以及普通堆,但大部分时候堆就是指二叉堆 二叉堆的定义 一棵完全...

  • 二叉堆的Python实现

    二叉堆(binary heap)是一种特殊的堆,二叉堆是完全二叉树或者是近似完全二叉树。二叉堆满足堆特性:父节点的...

  • Sort.堆排序(heapsort) & 优先队列

    二叉堆 这个二叉堆和先进后出的那个堆不是一个。而且这个二叉堆从下标1开始存储元素。 这里的二叉堆是个数组,也可以看...

  • 二叉树(二)-二叉堆

    1.什么是二叉堆 二叉堆是一种特殊的堆,二叉堆是完全二元树(二叉树)或者是近似完全二元树(二叉树)。二叉堆有两种:...

  • PriorityQueue源码解析

    PriorityQueue 一个基于优先级堆的无界优先级队列。 二叉堆 可视化操作:二叉堆 二叉堆(The bin...

  • 数据结构(8) 二叉堆

    二叉堆是一种特殊的堆,二叉堆是完全二元树(二叉树)或者是近似完全二元树(二叉树)。 二叉堆实用数组来表示,存贮节点...

网友评论

      本文标题:二叉堆

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