Java 与排序算法(5):归并排序

news2025/2/27 14:14:00

一、归并排序

归并排序(Merge Sort)是一种基于分治思想的排序算法。它将待排序的数组分成两个长度相等的子数组,然后对这两个子数组分别进行归并排序,最后将两个排好序的子数组合并成一个有序的数组。

具体实现过程如下:

  1. 将待排序的数组分成两个长度相等的子数组;
  2. 对这两个子数组分别进行归并排序,即递归地调用归并排序函数;
  3. 将两个排好序的子数组合并成一个有序的数组。

在这里插入图片描述

二、归并排序的性质

归并排序具有以下性质:

  1. 稳定性:归并排序是一种稳定的排序算法,即相等元素的相对位置在排序前后不会发生改变。

  2. 时间复杂度:归并排序的时间复杂度为 O(nlogn),其中 n 表示待排序数组的长度。归并排序的时间复杂度比较稳定,不会因为数据的分布情况而产生较大的波动。

  3. 空间复杂度:归并排序的空间复杂度为 O(n),其中 n 表示待排序数组的长度。归并排序需要额外的空间来存储归并过程中的临时数组,因此空间复杂度比较高。

  4. 适用性:归并排序适用于所有数据类型,尤其适用于链表数据结构。在链表数据结构中,归并排序的空间复杂度可以优化为 O(1)。

  5. 可并行性:归并排序具有很好的可并行性,可以将待排序数组分成多个子数组,分别进行排序,最后将排序好的子数组合并成一个有序的数组。

三、归并排序的变种

归并排序有以下几种变种:

  1. 自然归并排序(Natural Merge Sort):自然归并排序是归并排序的一种变种,它可以对已经部分有序的数组进行排序,从而提高排序效率。自然归并排序的基本思想是将待排序数组中已经有序的子序列合并成一个更大的有序序列,然后再将这些有序序列合并成一个完整的有序序列。

  2. 两路归并排序(Two-Way Merge Sort):两路归并排序是归并排序的一种变种,它可以在原地进行排序,即不需要额外的空间来存储归并过程中的临时数组。两路归并排序的基本思想是将待排序数组分成两个子数组,然后将这两个子数组合并成一个有序的数组。

  3. 多路归并排序(Multi-Way Merge Sort):多路归并排序是归并排序的一种变种,它可以对多个有序数组进行排序,从而提高排序效率。多路归并排序的基本思想是将待排序数组分成多个子数组,然后将这些子数组合并成一个有序的数组。多路归并排序可以使用堆来实现,从而提高排序效率。

  4. 原地归并排序(In-Place Merge Sort):原地归并排序是归并排序的一种变种,它可以在原地进行排序,即不需要额外的空间来存储归并过程中的临时数组。原地归并排序的基本思想是将待排序数组分成多个子数组,然后将这些子数组合并成一个有序的数组。原地归并排序需要使用插入排序来对小数组进行排序,从而提高排序效率。

四、Java 实现

以下是 Java 实现归并排序的示例代码:

public class MergeSort {
    public static 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);
    }
    public static 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 p = 0; p < temp.length; p++) {
            arr[left + p] = temp[p];
        }
    }
    public static void main(String[] args) {
        int[] arr = {5, 2, 8, 3, 6, 1, 7, 9, 4};
        mergeSort(arr, 0, arr.length - 1);
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
    }
}

在上述代码中,mergeSort 方法实现了归并排序的递归调用,merge 方法实现了归并排序的合并过程。在 main 方法中,我们可以调用 mergeSort 方法对数组进行排序。

五、归并排序的应用场景

归并排序适用于以下场景:

  1. 大规模数据的排序:归并排序的时间复杂度为 O(nlogn),其中 n 表示待排序数组的长度。因此,归并排序适用于大规模数据的排序。

  2. 外部排序:归并排序可以对外部存储器中的大规模数据进行排序,因为归并排序可以将待排序数据分成多个子数组,分别进行排序,最后将排序好的子数组合并成一个有序的数组。

  3. 链表排序:归并排序适用于链表数据结构的排序,因为链表数据结构不支持随机访问,而归并排序可以在链表数据结构中进行排序。

  4. 稳定排序:归并排序是一种稳定的排序算法,即相等元素的相对位置在排序前后不会发生改变。因此,如果需要保持相等元素的相对位置不变,可以使用归并排序进行排序。

六、归并排序在spring 中的应用

在 Spring 中,归并排序并不是一个常用的算法,因此在 Spring 框架中并没有直接使用归并排序的场景。但是,在 Spring 框架中有很多需要排序的场景,例如对 Bean 的属性进行排序、对集合进行排序等。在这些场景下,Spring 通常会使用 Java 中的排序方法,例如 Arrays.sort() 或 Collections.sort() 方法,这些方法都是使用快速排序或归并排序等高效的排序算法进行排序的。因此,可以说归并排序在 Spring 中的应用是间接的,通过 Java 中的排序方法进行应用的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/560718.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【国内chatgpt使用方法合集】(5月22日已更新)

写在前面 Hello大家好&#xff0c; 我是【麟-小白】&#xff0c;一位软件工程专业的学生&#xff0c;喜好计算机知识。希望大家能够一起学习进步呀&#xff01;本人是一名在读大学生&#xff0c;专业水平有限&#xff0c;如发现错误或不足之处&#xff0c;请多多指正&#xff0…

Elasticsearch文档操作:初学者指南(2023年最新版包含DSL语句的使用和RestHighLevelClient在Java中的使用)

2023年还没有学习Elasticsearch?&#xff0c;那么您将错过最强大、最通用的编程语言之一。 本文将介绍在Elasticsearch对文档分别使用DSL语句和Java High Level REST ClientAPI来对文档进行操作。获取更多信息查看官网帮助文档 运行环境&#xff1a; Linux&#xff0c;docke…

驱动开发DAY6

非阻塞IO 在应用程序中读取硬件数据时&#xff0c;无论硬件数据是否准备完毕&#xff0c;read&#xff08;&#xff09;函数不会阻塞&#xff0c;继续向下执行 阻塞IO 当应用程序中读取硬件数据时&#xff0c;在硬件数据没有准备好时&#xff0c;进程会阻塞在read&#xff08;&…

C语言——如何写出好的代码?

哈喽&#xff0c;大家好&#xff0c;今天我们来学习如何才能写出优秀的代码&#xff0c;主要讲的是assert和const的用法。 首先&#xff0c;什么样的代码才算的上是优秀的代码呢&#xff1f;应该符合下面的要求&#xff1a; 1. 代码运行正常 2. bug很少 3. 效率高 4. 可读性高 …

自抗扰PID(梯形图源代码)

有关ADRC的详细算法和源代码,请参看专栏的系列文章,这里不再赘述,常用链接如下: ADRC自抗扰控制算法(含梯形图完整源代码和算法公式)_adrc算法_RXXW_Dor的博客-CSDN博客PLC的自抗扰控制(ADRC)算法_RXXW_Dor的博客-CSDN博客_adrc算法1、自抗扰控制算法,网上很多文章有所…

x210---根文件系统制作

一、busybox的移植 1.1、busybox源码下载 (1)busybox是一个开源项目&#xff0c;所以源代码可以直接从网上下载。 (2)busybox的版本差异不大&#xff0c;版本新旧无所谓。 (3)下载busybox可以去linuxidc等镜像网站&#xff0c;也可以去www.busybox.net官方网站下载。 1.2、修…

技术人如何写简历?(文末有福利)

前言 笔者在滴滴、阿里和字节时候也面试了不少人&#xff0c;看过形形色色的简历没有上百也有大几十份了。校招季也快到了&#xff0c;这里总结自身经验聊一下 技术人的简历如何去写面试官是怎么样从一份简历去开展后续的面试 简历的作用 简历是你向一家公司求职的“敲门砖…

数据结构学习之路-集合

集合Set 集合的特点集合的内部实现&#xff08;使用链表&#xff09;集合的内部实现&#xff08;使用红黑树&#xff09;复杂度分析使用红黑树实现集合的限制 集合的特点 不存放重复的元素常用于去重 例如&#xff1a;存放新增的IP地址&#xff0c;统计新增IP量&#xff1b;存…

torch中的model.eval()、model.train()详解

&#x1f468;‍&#x1f4bb;个人简介&#xff1a; 深度学习图像领域工作者 &#x1f389;工作总结链接&#xff1a;https://blog.csdn.net/qq_28949847/article/details/128552785 链接中主要是个人工作的总结&#xff0c;每个链接都是一些常用demo&#xff0c…

Laravel框架05:模型和自动验证

Laravel框架05&#xff1a;模型和自动验证 一、模型&#xff08;AR模式&#xff09;概述二、定义模型三、调用模型四、基本操作1. 添加数据① AR模式② Request 2. 查询数据3. 修改操作① AR模式② update 4. 删除操作 五、控制器验证1. 基本语法2. 输出错误信息 一、模型&…

今麦郎跻身“我最喜欢中国品牌”榜,致力领航中国品牌发展新范式

在中国经济探寻高质量发展的当下&#xff0c;中国民营企业肩负着推动经济发展的重任。在当前中国经济向上向前的大背景下&#xff0c;展示中国特色、传播中国文化、践行社会责任多位一体的高质量品牌越来越受到重视。但冰冻三尺非一日之功&#xff0c;唯有经历时间考验&#xf…

Spring:Spring 整合 MyBatis 的具体过程

文章目录 Spring&#xff1a;Day 04整合 MyBatis一、配置环境1. 导入依赖2. 准备一个数据库 二、用 Spring 整合 MyBatis1. 编写通用配置文件2. 编写实现类3. 编写 Spring 配置文件4. 测试5. 分析总结 三、拓展1. 实现2. 总结 四、事务1. 概述2. 没有事务时3. 声明式事务4. 总结…

“Shell“SNAT,DNAT

文章目录 一.SNAT1.1 SNAT原理1.2 SNAT的应用环境1.3 SNAT工作原理1.4 进行SNAT转换后1.5 配置SNAT策略1.6SNAT实验 二.DNAT2.1 DNAT工作原理2.2 配置DNAT策略2.3 DNAT实验 一.SNAT 1.1 SNAT原理 SNAT原理&#xff1a;修改数据包的源地址。SNAT 应用环境&#xff1a;局域网主…

基础学习——关于卷积层的记录

文章目录 前言一、功能层1、池化层2、nn.BatchNorm2d()3、全连接层4、softmax层 二、卷积层1、普通卷积2、空洞卷积3、多尺度卷积4、分组卷积5、深度可分离卷积6、形变卷积 前言 老是忘有些模块的具体作用&#xff0c;记录一下。 一、功能层 1、池化层 池化层夹在连续的卷积…

总结最全面的TCP、UDP、Socket、HTTP网络编程面试题

先看一天面试的经验&#xff1a; 第一场&#xff1a; 面试官&#xff1a;你说一下TCP的三次握手 我&#xff1a;第一次Client将SYN置1......、第二次Server收........、 第三次........ 面试官&#xff1a;很难背吧&#xff1f; 我&#xff1a;......是啊&#xff0c;很难&…

harbor安装

文章目录 先决条件硬件软件网络端口 安装docker签发证书生成证书颁发机构证书 生成服务器证书向 Harbor 和 Docker 提供证书 下载harbor安装包containerd 配置私有仓库&#xff08;二选一&#xff09;分发证书(如上文只是路径变了)配置登录加密登录打标签并推送与拉取 docker 配…

【EasyPoi实战系列】Spring Boot使用EasyPoi动态控制导出的列 - 第471篇

历史文章&#xff08;文章累计460&#xff09; 《国内最全的Spring Boot系列之一》 《国内最全的Spring Boot系列之二》 《国内最全的Spring Boot系列之三》 《国内最全的Spring Boot系列之四》 《国内最全的Spring Boot系列之五》 《国内最全的Spring Boot系列之六》 用…

机器学习神经网络——GBDT(Gradient Boosting Decision Tree 梯度提升决策树)算法

系列文章目录 机器学习神经网络——Adaboost分离器算法 机器学习之SVM分类器介绍——核函数、SVM分类器的使用 机器学习的一些常见算法介绍【线性回归&#xff0c;岭回归&#xff0c;套索回归&#xff0c;弹性网络】 文章目录 系列文章目录 前言 一、GBDT(Gradient Boos…

计算机网络:物理层

物理层 1. 通信基础1.1 基本概念1.1.1 通信模型1.1.2 通信方式1.1.3 数据传输方式1.1.4 数据同步的传输/通信方式1.1.5 码元1.1.6 速率1.1.7 带宽 1.2 奈氏准则|香农定理1.2.1 奈氏准则1.2.2 香农定理 1.3 编码、调制1.3.1 数字数据编码为数字信号1.3.2 数字数据调制为模拟信号…

Google Colab的使用方法

什么是 Google Colab&#xff1f; Colaboratory是一个 Google 研究项目&#xff0c;旨在帮助传播机器学习培训和研究成果。是一个Jupyter 笔记本环境&#xff0c;不需要进行任何设置就可以使用&#xff0c;并且完全在云端运行。Colaboratory笔记本存储在 Google 云端硬盘中&…