建小堆与向下调整-堆

package cn.tan.heap;

//建立小堆的过程
public class HeapTest {
    public static void shiftDown(long[] arr,int size,int index){
        while(true){
            int left=2*index+1;
            //先判定左节点
            if(left>=size){
                return;
            }
            int right=left+1;
            int min=left;
            //在判定右节点
            if(right<size&&arr[right]<arr[left]){
                min=right;
            }
            //在比较双亲和孩子的大小
            if(arr[index]<=arr[min]){
                return;
            }
            swap(arr,min,index);
            index=min;
        }
    }

    private static void swap(long[] arr, int min, int index) {
        long t = arr[index];
        arr[index] = arr[min];
        arr[min] = t;
    }

    //建堆这里就是建一个小堆就是对一个数组进行调整
    public static void createHeap(long[] arr,int size){
        //叶节点是不用进行向下调整的
        for(int i=(size-2)/2;i>=0;i--){
            shiftDown(arr,size,i);
        }
    }

    public static void main(String[] args) {
//        long[] array = { 2, 5, 1, 7, 13, 3, 5, 9, 8 };
//        long[] array = { 27, 15, 19, 18, 28, 34, 65, 49, 25, 37 };
        long[] array = {1, 9, 1, 7, 2, 3, 2, 8, 5, 4, 3, 0, 1};
        createHeap(array, array.length);
    }
}

1.向下调整是当前节点与两个孩子中最值的比较

2.建堆的过程其实就是对数组进行调整的过程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值