归并排序(Java)

一、一句话总结

分治:先分成两半分别排序,再合并两个有序数组


二、核心代码

java 复制代码
public void mergeSort(int[] arr, int left, int right) {
    if (left >= right) return;
    
    int mid = (left + right) / 2;
    mergeSort(arr, left, mid);      // 排左边
    mergeSort(arr, mid + 1, right); // 排右边
    merge(arr, left, mid, right);   // 合并
}

private void merge(int[] arr, int left, int mid, int right) {
    int[] temp = new int[right - left + 1];
    int i = left, j = mid + 1, k = 0;
    
    while (i <= mid && j <= right) {
        if (arr[i] <= arr[j]) temp[k++] = arr[i++];
        else temp[k++] = arr[j++];
    }
    while (i <= mid) temp[k++] = arr[i++];
    while (j <= right) temp[k++] = arr[j++];
    
    for (int t = 0; t < temp.length; t++) {
        arr[left + t] = temp[t];
    }
}

三、复杂度

指标
时间复杂度 O(n log n)(最好/最坏/平均都一样)
空间复杂度 O(n)(需要临时数组)
稳定性 ✅ 稳定

四、记忆口诀

左边排,右边排,两个有序合并来
临时数组存结果,最后拷贝回原数组


五、一句话记住

归并排序 = 分治 + 合并,稳定但费空间

相关推荐
逆境不可逃2 小时前
一篇速通互联网架构的不断升级过程:从单机到云原生
java·elasticsearch·搜索引擎·云原生·架构
YUDAMENGNIUBI4 小时前
day20_逻辑回归
算法·机器学习·逻辑回归
scott.cgi4 小时前
Unity直接编译Java文件作为插件,导致失败的两个打包设置
java·unity·unity调用java·unity的java文件·unity的android插件·unity调用android·unity加载java代码
澈2078 小时前
C++并查集:高效解决连通性问题
java·c++·算法
旖-旎10 小时前
深搜练习(单词搜索)(12)
c++·算法·深度优先·力扣
2401_8734794010 小时前
运营活动被薅羊毛怎么防?用IP查询+设备指纹联动封堵漏洞
java·网络·tcp/ip·github
ShiJiuD66688899910 小时前
大事件板块一
java
摇滚侠10 小时前
@Autowired 和 @Resource 的区别
java·开发语言
SeaTunnel10 小时前
(八)收官篇 | 数据平台最后一公里:数据集成开发设计与上线治理实战
java·大数据·开发语言·白鲸开源