归并排序算法(Java实现)

1.归并排序算法思想

也称合并排序算法 ,是将两个或两个以上的有序数据序列合并成一个新的有序数据序列。该算法采用分治法(Divide and Conquer)的思想,将待排序的序列分成若干个子序列,分别对子序列进行排序,然后将有序的子序列合并成一个大的有序序列

注:将几个有序队列合并成一个新的有序数据队列就称为几路归并排序算法

2.归并排序算法实现步骤

归并排序的基本步骤如下:
(1)分解

将待排序的序列分成若干个子序列,每个子序列都是有序的。这是通过递归实现的,每次递归都将原序列分成两个子序列
(2)解决

对每个子序列进行排序。这是通过递归调用的方式实现的,递归调用归并排序函数对子序列进行排序。
(3)归并

将已排序的子序列归并成一个大的有序序列。这是通过归并操作实现的,将两个有序的子序列归并成一个新的有序序列。在归并的过程中,采用归并算法(Merge Algorithm)将两个有序的子序列归并成一个新的有序序列。具体操作如下:

1)初始化两个指针i和j,分别指向两个子序列的起始位置。

2)比较两个指针所指向的元素,将较小的元素复制到一个临时数组中,然后将指针加1,继续比较下一个元素。

3)当一个指针到达子序列的末尾时,将另一个子序列剩余的元素复制到临时数组中。

4)将临时数组中的元素复制回原数组,完成合并操作。
通过递归调用和合并操作,最终得到一个有序的序列

3.归并排序算法性能分析

性能 性能指标
最坏时间复杂度 O ( n log ⁡ 2 n ) O(n\log_{2^n}) O(nlog2n)
最好时间复杂度 O ( n log ⁡ 2 n ) O(n\log_{2^n}) O(nlog2n)
平均时间复杂度 O ( n log ⁡ 2 n ) O(n\log_{2^n}) O(nlog2n)
空间复杂度 O(n)
稳定性 稳定

4.归并排序算法代码实现(Java实现)

java 复制代码
public class Demo {
    public static void main(String[] args) {
        int[] arr = new int[]{1,2,3,4,5,6,7,8,9,10};
        mergeSort(arr,0,arr.length-1);
        for(int i:arr){
            System.out.println(i);
        }
    }
    //归并排序的归并操作
    public static void merge(int[] arr,int low,int mid ,int high){
        int i,j,k;
        int[] tempArr = new int[arr.length];//辅助数据
        for(k = low; k <=high; k++){ //将原数组复制到辅助数组中
            tempArr[k] = arr[k];
        }
        //arr[low...mid]和arr[mid+1...high]各自有序,将两个部分归并
        for(i=low, j=mid+1, k=i; i<=mid && j <= high; k++){
            if(tempArr[i] > tempArr[j]){ //">"号代表升序,"<"号代表降序
                arr[k] = tempArr[i++];
            }else{
                arr[k] = tempArr[j++];
            }
        }
        while(i <= mid){ //将左半部分的剩余元素依次放入到新数组中
            arr[k] = tempArr[i++];
            k++;
        }
        while( j <= high){ //将右半部分的剩余元素依次放入到新数组中
            arr[k] = tempArr[j++];
            k++;
        }
    }
    //归并排序的递归部分
    public static void mergeSort(int[] arr,int low,int high){
       if(low < high){ // 递归结束条件
           int mid = (low + high)/2;
           mergeSort(arr,low,mid); //对数组左半部分归并排序
           mergeSort(arr,mid+1,high); //对数组右半部分归并排序
           merge(arr,low,mid,high); //归并
       }
    }
}
相关推荐
ChineHe2 分钟前
基础篇003_Python基础语法
开发语言·人工智能·python
学编程就要猛2 分钟前
JavaEE初阶:文件操作和IO
java·java-ee
ba_pi3 分钟前
每天写点什么2026-03-19-Doris三种存储模型
java·数据库·mysql
程序员老乔6 分钟前
Java 新纪元 — JDK 25 + Spring Boot 4 全栈实战(二):Valhalla落地,值类型如何让电商DTO内存占用暴跌
java·spring boot·c#
SuniaWang12 分钟前
《Spring AI + 大模型全栈实战》学习手册系列· 专题二:《Milvus 向量数据库:从零开始搭建 RAG 系统的核心组件》
java·人工智能·分布式·后端·spring·架构·typescript
Klong.k13 分钟前
判断是不是素数题目
数据结构·算法
QQsuccess13 分钟前
AI全体系保姆级详讲——第一部分:了解AI基本定义
人工智能·算法
张小洛15 分钟前
Spring 常用类深度剖析(工具篇 02):ReflectionUtils——优雅操作反射的利器
java·后端·spring·工具类·spring常用类
_日拱一卒16 分钟前
LeetCode:移动零
算法·leetcode·职场和发展
沉沙丶18 分钟前
关于matlab分析电流THD的一些探究和记录
开发语言·matlab·电机控制·foc·永磁同步电机·模型预测·预测控制