java归并排序

java归并排序

归并排序分三步:

1.把数组分成左右两部分

2.把左右两部分都当成单独的数组继续分

3.排序:当不能再分的时候,对最小的左右两个数组进行比较排序。这个排序是拿两个数组的第i和j比,i小则j和i++比,把i放进新数组,j小则i和j++比,把j放进新数组里面。

相当于把数组排序分成许多小数组排序。

java 复制代码
public int[] merge(int[] nums1,int[] nums2) {
        //把传进来的左右数组进行一个一个元素相互比较,i和j比,i小则j和i++比,把i放进新数组,j小则i和j++比,把j放进新数组
        int m=nums1.length;
        int n=nums2.length;
        //创建一个新数组
        int[] arr=new int[m+n];
        //分别比较两个数组的元素,将小的添加到新数组
        int index=0,i=0,j=0;
        while(i<m&&j<n){
            if(nums1[i]>nums2[j]){
                arr[index]=nums2[j];
                j++;
            }else{
                arr[index]=nums1[i];
                i++;
            }
            index++;
        }
        //将剩余的元素添加到新数组中
        while(i<m){
            arr[index]=nums1[i];
            i++;
            index++;
        }
        while(j<n){
            arr[index]=nums2[j];
            j++;
            index++;
        }
        return arr;
    }
    public int[] sort(int[] nums){
        //递归中止条件:
        if(nums.length==0||nums.length==1){
            return nums;
        }

        //分割成左右两部分
        int[] left= Arrays.copyOfRange(nums,0,nums.length/2);
        int[] right= Arrays.copyOfRange(nums,nums.length/2,nums.length);
        //然后左右两部分分别排序
        //把左或右部分继续分割排序
        return merge(sort(left),sort(right));
    }
相关推荐
CoovallyAIHub3 分钟前
YOLO-Maste开源:首个MoE加速加速实时检测,推理提速17.8%!
深度学习·算法·计算机视觉
清铎7 分钟前
leetcode_day13_普通数组_《绝境求生》
数据结构·算法
涵涵(互关)9 分钟前
JavaScript 对大整数(超过 2^53 - 1)的精度丢失问题
java·javascript·vue.js
进击的丸子9 分钟前
基于虹软Linux Pro SDK的多路RTSP流并发接入、解码与帧级处理实践
java·后端·github
小北方城市网10 分钟前
微服务架构设计实战指南:从拆分到落地,构建高可用分布式系统
java·运维·数据库·分布式·python·微服务
开开心心_Every12 分钟前
离线黑白照片上色工具:操作简单效果逼真
java·服务器·前端·学习·edge·c#·powerpoint
予枫的编程笔记12 分钟前
【Java进阶】深入浅出 Java 锁机制:从“单身公寓”到“交通管制”的并发艺术
java·人工智能·
while(1){yan}16 分钟前
SpringAOP
java·开发语言·spring boot·spring·aop
专注于大数据技术栈16 分钟前
java学习--Collection
java·开发语言·学习
heartbeat..17 分钟前
Spring 全局上下文实现指南:单机→异步→分布式
java·分布式·spring·context