可能内存溢出的高级排序算法-归并排序

归并排序

归并排序在经典递归实现中需要的额外空间相对较多。这是因为在归并排序的过程中,需要与原始数组大小相同的额外空间来存储临时合并的数组。所以,其空间复杂度为O(n),其中n表示待排序数组的长度。在递归过程中,需要创建临时数组来存储分割后的子数组,这些临时数组会随着递归的进行不断地被创建和释放。

powershell 复制代码
相比快速排序算法,归并排序在任何情况下都是O(nlogn),而快速排序在最坏的情况下是O(n的平方)

算法代码如下:

powershell 复制代码
class Solution {
    public int[] sortArray(int[] nums) {
            return mergeSort(nums, 0, nums.length-1);
    }
    public static int[] mergeSort(int[] nums, int l, int r){

        if(l==r){
            int[] newsz=new int[1];
            newsz[0]=nums[l];
            return newsz;
        }
        int mid=(l+r)/2;
        int[] mergeSort1 = mergeSort(nums, l, mid);
        int[] mergeSort2 = mergeSort(nums, mid + 1, r);
        int[] sum=new int[mergeSort1.length+mergeSort2.length];

        int m=0,i=0,j=0;
        while (i<mergeSort1.length&&j<mergeSort2.length) {
            if (mergeSort1[i] <= mergeSort2[j]) {
                sum[m++] = mergeSort1[i++];
            } else {
                sum[m++] = mergeSort2[j++];
                }
            }
            while (j<mergeSort2.length){
                sum[m++]=mergeSort2[j++];
            }
            while (i<mergeSort1.length){
                sum[m++]=mergeSort1[i++];
            }
        return sum;
    }
}
相关推荐
Propeller10 分钟前
【Android】View 交互的事件处理机制
android·java
杨杨杨大侠13 分钟前
Atlas Mapper 教程系列 (5/10):集合映射与嵌套对象处理
java·开源·github
ERP老兵_冷溪虎山14 分钟前
Python/JS/Go/Java同步学习(第十三篇)四语言“字符串转码解码“对照表: 财务“小南“纸式转码术处理凭证乱码崩溃(附源码/截图/参数表/避坑指南)
java·后端·python
是2的10次方啊15 分钟前
如何设计10万QPS秒杀系统?缓存+消息队列+分布式锁架构实战
java
心灵宝贝16 分钟前
Tomcat Connectors 1.2.37 源码编译安装教程(mod_jk 详细步骤)
java·tomcat
杨杨杨大侠18 分钟前
Atlas Mapper 教程系列 (6/10):Spring Boot 集成与自动配置
java·开源·github
傻傻虎虎28 分钟前
【Docker】容器端口暴露+镜像生成实战
java·docker·容器
练习时长一年39 分钟前
搭建langchain4j+SpringBoot的Ai项目
java·spring boot·后端
九术沫1 小时前
装饰器模式在Spring中的案例
java·spring·装饰器模式
Rysxt_1 小时前
Spring Boot 集成 Spring AI OpenAI Starter 教程
java·spring boot·后端·ai