堆排序算法

时间复杂度o(nlogn)
给一个无序数组,使用堆排序实现数组有序
步骤 此处演示大顶堆
1.数组构建为大顶堆
2.数组arr[0] 和arr[arr.length - 1] 值交换,length–
3.继续进行堆调整
public void sort(int[] arr){
    //构建大顶堆   从下往上开始  第一个非叶子节点 arr.length/2-1 位置起
    for(int i = arr.length/2-1;i >= 0; i--){
        adjustHeap(arr,i,arr.length);
    }
    //调整堆结构
    for(int i = arr.length-1;i > 0; i--){
        //将最大值与末尾数值交换,最大值放到数组末尾   并且i--
        swap(arr,0 , i);
        //交换之后 不满足堆  继续调整,调整时从根节点 arr[0]开始
        adjustHeap(arr,0,i);
    }

}

private void adjustHeap(int[] arr, int i, int length){
    int temp = arr[i];
    //定位到节点i的左孩子节点
    for(int j = i*2+1;j < length; j = j*2+1){
        if(j + 1 < length && arr[j+1] > arr[j]){
            j++;
        }
        if(arr[j] > temp){
            //如果孩子节点的值大于其节点的值、两者交换
            swap(arr, i, j);
            i = j;
        }else{
            break;
        }
    }
    arr[i] = temp;
}

//交换数组节点的值
private void swap(int[] arr, int i, int j){
    int temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值