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));
    }
相关推荐
要开心吖ZSH2 分钟前
AI医疗分诊与健康咨询助手agent开发——(1)从零搭建SpringBoot与AI对话系统:后端骨架 + 前端对话页 + SSE流式输出
java·ai·agent·健康医疗
biubiubiu07064 分钟前
SpringBoot生产级日志配置
java·spring boot·后端
hnjzsyjyj9 分钟前
东方博宜OJ 1010:数组元素的排序 ← 桶排序
数据结构·排序算法·桶排序
ch.ju13 分钟前
Java Programming Chapter 4——Inherited call
java·开发语言
是有头发的程序猿16 分钟前
竞品分析 + 用户洞察自动化|基于 item_review 评论接口 + 多 AI Agent 实现淘宝评论全量采集与智能分析(附python源码)
java·python·自动化
小欣加油19 分钟前
Leetcode31 下一个排列
数据结构·c++·算法·leetcode·职场和发展
凤凰院凶涛QAQ22 分钟前
《Java版数据结构 & 集合类剖析》链表与LinkedList:节点手拉手,增删不用愁
java·数据结构·链表
唐青枫34 分钟前
Java MyBatis 实战指南:XML 映射、动态 SQL 与数据访问层设计
java·mybatis
码语智行34 分钟前
MQTT 配置、依赖与使用说明
java·物联网·mt
_日拱一卒35 分钟前
LeetCode:39组合总和
java·算法·leetcode·职场和发展