排序算法之归并排序

归并排序

简介

归并排序是一种分治思想的排序算法,它的基本思想是将待排序的数组分成若干个子序列,每个子序列都是有序的,然后再将子序列合并成一个有序的数组。

算法解析

归并排序的核心思想就是分治,将数组无限拆分到最小数组,然后在进行排序。也就是:使用递归拆分成N 个数组,拆分到不可在拆分是,对数组进行排序,这时候都是有序数组,在进行合并。

代码实现

java 复制代码
**
 * 归并排序
 */
public class MergeSort {

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


    public static void mergeSort(int[] arr, int left, int right){
        if (left < right){
            int mid = (right + left) / 2;
            mergeSort(arr, left, mid);
            mergeSort(arr, mid + 1, right);
            mergeData(arr, left, right, mid);
        }
    }

    /**
     * 归并数据
     * @param arr
     * @param left
     * @param right
     * @param mid
     */
    public static void mergeData(int[] arr, int left, int right, int mid){
        int[] temp = new int[(right - left +1)];
        int leftNum = (mid - left) + 1;
        int rightNum = (right - mid);
        System.arraycopy(arr, left, temp, 0, leftNum);
        System.arraycopy(arr, mid + 1, temp, leftNum, rightNum);

        int l = 0;
        int r = leftNum;
        int k = left;
        // 比较并将数据放回原始数组
        while (l < leftNum && r < temp.length){
            if (temp[l] < temp[r]){
                arr[k] = temp[l];
                l++;
            }else {
                arr[k] = temp[r];
                r++;
            }
            k++;
        }

        // 将剩下数据放回原始数组
        while (l < leftNum){
            arr[k] = temp[l];
            l++;
            k++;
        }
        while (r < temp.length){
            arr[k] = temp[r];
            r++;
            k++;
        }

    }

    public static void main(String[] args) {
        int[] arr = { 10, 7, 3, 3, 4, 2, 8, 1, 5, 9, 2, 1};
        sort(arr);
        System.out.println("arr:"+ JSON.toJSONString(arr));

    }
}

注意事项

归并排序的时间复杂度为O(nlogn),它的性能比冒泡排序和插入排序要好得多,特别是在大型列表上

相关推荐
云 无 心 以 出 岫几秒前
贪心算法QwQ
数据结构·c++·算法·贪心算法
圈圈编码2 分钟前
Spring Task 定时任务
java·前端·spring
俏布斯14 分钟前
算法日常记录
java·算法·leetcode
独好紫罗兰18 分钟前
洛谷题单3-P5719 【深基4.例3】分类平均-python-流程图重构
开发语言·python·算法
276695829219 分钟前
美团民宿 mtgsig 小程序 mtgsig1.2 分析
java·python·小程序·美团·mtgsig·mtgsig1.2·美团民宿
爱的叹息20 分钟前
Java 连接 Redis 的驱动(Jedis、Lettuce、Redisson、Spring Data Redis)分类及对比
java·redis·spring
程序猿chen30 分钟前
《JVM考古现场(十五):熵火燎原——从量子递归到热寂晶壁的代码涅槃》
java·jvm·git·后端·java-ee·区块链·量子计算
SheepMeMe1 小时前
蓝桥杯2024省赛PythonB组——日期问题
python·算法·蓝桥杯
随便昵称1 小时前
蓝桥杯专项复习——前缀和和差分
c++·算法·前缀和·蓝桥杯
脑子慢且灵1 小时前
蓝桥杯冲刺:一维前缀和
算法·leetcode·职场和发展·蓝桥杯·动态规划·一维前缀和