归并排序笔记

public static void mergeSort(int[] target){
    sort(target,0,target.length);
}

private static void sort(int[] target,int start,int end){
    if (end - start < 2){
        return;
    }

    int index = (end + start) >> 1;
    sort(target,start,index);
    sort(target,index,end);
    merge(target,start,end);
}

private static void merge(int[] target,int start,int end){
    int index = (start + end) >> 1;
    int[] arr = new int[end - start];
    int length = 0;
    for (int left = start,right = index;left < index && right < end ; length++){
        if (target[left] < target[right]){
            arr[length] = target[left];
            left++;
        }else {
            arr[length] = target[right];
            right++;
        }

        if (left == index){
            int x = end - right;
            System.arraycopy(target, right, arr, ++length, x);
            length = length + x - 1;
        }

        if (right == end){
            int x = index - left;
            System.arraycopy(target, left, arr, ++length, x);
            length = length + x - 1;
        }
    }

    if (length > 0) System.arraycopy(arr, 0, target, start, length);

}

原本想使用fork/join 实现归并排序,测试发现其实并不合适,虽然都是采用分治思想但是在归并排序中,执行粒度太小,创建线程不如执行,并且合并还需要等待。

推荐:当排序量比较庞大时,可以采用多线程,为了线程资源浪费,可以分块归并,并且主线程也要执行分块中的一部分,然后主线程执行完一部分后在进行子线程join操作进行等待,最终进行合并操作。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值