iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >图解Java中归并排序算法的原理与实现
  • 943
分享到

图解Java中归并排序算法的原理与实现

2024-04-02 19:04:59 943人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录一、基本思想二、算法分析1、算法描述2、过程分析3、动图演示三、算法实现一、基本思想 归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and C

一、基本思想

归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为2-路归并。

二、算法分析

1、算法描述

把长度为n的输入序列分成两个长度为n/2的子序列;对这两个子序列分别采用归并排序;将两个排序好的子序列合并成一个最终的排序序列。

2、过程分析

(1)、现在我们将拆分项 [1] (指数从 0 到 0,两边都包括) 和 [28] 指数从 1 到 1 ,两边都包括) 归并在一起。

(2)、因为 1 (左拆分) <= 28 (右拆分), 我们将 {rightPart} 拷进新的数组

(3)、因为左拆分是空的,我们将 28 (右拆分)拷进新的数组。

(4)、我们将新数组中的元素拷贝回原来的数组中。

(5)、因为 3 (左拆分) <= 21 (右拆分), 我们将 {rightPart} 拷进新的数组。

(6)、因为左拆分是空的,我们将 21 (右拆分)拷进新的数组。

(7)、现在我们将拆分项 [1,28] (指数从 0 到 1,两边都包括) 和 [3,21] 指数从 2 到 3 ,两边都包括) 归并在一起。

(8)、因为 1 (左拆分) <= 3 (右拆分), 我们将 {rightPart} 拷进新的数组。

(9)、因为 28 (左拆分) > 3 (右拆分), 我们将 {rightPart} 拷进新的数组。

(10)、因为 28 (左拆分) > 21 (右拆分), 我们将 {rightPart} 拷进新的数组。

(11)、因为右拆分是空的,我们将28 (左拆分) 拷贝进新的数组。

(12)、我们将新数组中的元素拷贝回原来的数组中。

(13)、现在我们将拆分项 [11] (指数从 4 到 4,两边都包括) 和 [7] 指数从 5 到 5 ,两边都包括) 归并在一起。

(14)、因为 11 (左拆分) > 7 (右拆分), 我们将 {rightPart} 拷进新的数组。

(15)、因为右拆分是空的,我们将11 (左拆分) 拷贝进新的数组。

(16)、我们将新数组中的元素拷贝回原来的数组中。

(17)、以此类推

(18)、因为 1 (左拆分) <= 6 (右拆分), 我们将 {rightPart} 拷进新的数组。

(19)、因为 3 (左拆分) <= 6 (右拆分), 我们将 {rightPart} 拷进新的数组。

(20)、因为 21 (左拆分) > 6 (右拆分), 我们将 {rightPart} 拷进新的数组。

(21)、因为 21 (左拆分) > 7 (右拆分), 我们将 {rightPart} 拷进新的数组。

(22)、以此类推,我们将新数组中的元素拷贝回原来的数组中。

3、动图演示

三、算法实现

package com.alGorithm.tenSortingAlgorithm;

import java.util.Arrays;

public class MergeSort {
    private 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); //合并
        }
    }

    private static void merge(int[] arr, int low, int mid, int high) {
        int[] temp = new int[arr.length]; //辅助数组
        int k = 0, i = low, j = mid + 1; //i左边序列和j右边序列起始索引,k是存放指针
        while (i <= mid && j <= high) {
            if (arr[i] <= arr[j]) {
                temp[k++] = arr[i++];
            } else {
                temp[k++] = arr[j++];
            }
        }
        //如果第一个序列未检测完,直接将后面所有元素加到合并的序列中
        while (i <= mid) {
            temp[k++] = arr[i++];
        }
        //同上
        while (j <= high) {
            temp[k++] = arr[j++];
        }
        //复制回原数组
        for (int t = 0; t < k; t++) {
            arr[low + t] = temp[t];
        }
    }

    public static void main(String[] args) {
        int[] arr = {1,28,3,21,11,7,6,18};
        mergeSort(arr, 0, arr.length - 1);
        System.out.println(Arrays.toString(arr));
    }
}

到此这篇关于图解Java中归并排序算法的原理与实现的文章就介绍到这了,更多相关Java归并排序内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 图解Java中归并排序算法的原理与实现

本文链接: https://www.lsjlt.com/news/165934.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 图解Java中归并排序算法的原理与实现
    目录一、基本思想二、算法分析1、算法描述2、过程分析3、动图演示三、算法实现一、基本思想 归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and C...
    99+
    2024-04-02
  • 图解Java经典算法归并排序的原理与实现
    目录归并排序算法原理动图演示代码实现复杂度归并排序 归并排序主要分成两部分实现,分、合两部分,分是把数组分成两半,再递归的对子数组进行 分 操作,直到分成一个个单独的数。合是把两个数...
    99+
    2024-04-02
  • 图解Java排序算法之归并排序
    目录基本思想合并相邻有序子序列代码实现总结基本思想 归并排序(MERGE-SORT)是利用归并的思想实现的排序方法,该算法采用经典的分治(divide-and-conquer)策略(...
    99+
    2024-04-02
  • 图解Java中插入排序算法的原理与实现
    目录一、基本思想二、算法分析1、算法描述2、过程分析三、算法实现一、基本思想 插入排序(Insertion-Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序...
    99+
    2024-04-02
  • Java 归并排序算法、堆排序算法实例详解
    基本思想:  归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序子序列合并为整体有序序列。归并排序示例:合并方法:设r[i…n]由两个有序子表r[i…m...
    99+
    2023-05-31
    java 归并排序 堆排序
  • Java 语言实现归并排序算法
    【引言】 归并排序算法是一种高效且稳定的排序算法。它采用分治法的思想,将数组反复分割成两个子数组,直到每个子数组只有一个元素。然后将这些子数组逐个合并,最终得到排序完毕的数组。本文将使用Java语言实现归并排序算法,并详细讲解其核心思想和代...
    99+
    2023-08-30
    排序算法 java 算法
  • Java排序算法之归并排序简单实现
    算法描述:对于给定的一组记录,首先将每两个相邻的长度为1的子序列进行归并,得到 n/2(向上取整)个长度为2或1的有序子序列,再将其两两归并,反复执行此过程,直到得到一个有序序列。package sorting;public class M...
    99+
    2023-05-30
    java算法 归并排序 ava
  • java怎么实现归并排序算法
    归并排序算法的实现步骤如下:1. 首先,实现一个归并操作函数。该函数将两个已排序的数组合并为一个新的已排序的数组。例如:```jav...
    99+
    2023-08-15
    java
  • 图解Java经典算法快速排序的原理与实现
    目录快速排序算法原理图解Java代码实现算法分析快速排序 通过一趟排序将待排元素分成独立的两部分,其中一部分为比基准数小的元素,另一部分则是比基准数大的元素。然后对这两部分元素再按照...
    99+
    2024-04-02
  • 图解Java经典算法插入排序的原理与实现
    目录一、算法介绍二、算法思想三、算法原理四、动图演示五、代码实现六、算法分析6.1 时间复杂度6.2 空间复杂度一、算法介绍 插入排序,也称为直接插入排序。插入排序是简单排序中效率最...
    99+
    2024-04-02
  • 图解Java经典算法希尔排序的原理与实现
    目录希尔排序算法思想图解代码实现(Java)希尔排序 希尔排序时插入排序的一种,也称缩小增量排序,是直接插入排序的一种更高效的改进版本。希尔排序是非稳定排序算法。 算法思想 希尔排序...
    99+
    2024-04-02
  • 图解Java经典算法冒泡排序的原理与实现
    目录冒泡排序算法原理动图演示算法练习算法分析冒泡排序 冒泡排序是一种比较简单的排序算法,我们可以重复遍历要排序的序列,每次比较两个元素,如果他们顺序错误就交换位置,重复遍历到没有可以...
    99+
    2024-04-02
  • 如何在Java与Python实现一个归并排序算法
    如何在Java与Python实现一个归并排序算法?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。归并排序里运用到算法里很重要的一个思想——分治法:将原问题分解为几个规模较小但...
    99+
    2023-05-31
    归并排序 java python
  • php实现归并排序算法的方法详解
    目录php实现归并排序算法归并排序原理总结php实现归并排序算法 归并排序算法的复杂度是O(nlogn)。 代码如下,只需要clone下来执行composer install然后执行...
    99+
    2024-04-02
  • Python实现希尔排序算法并附带原理图解
    Shell排序算法是插入排序算法的强化版本。算法将原始集合分解为更小的子集,然后使用插入排序对每个子集进行排序。 Shell排序算法中可以使用的最佳序列 原始序列:N/2,N/4,…,1 诺斯增量序列:1,4,13,…,(3k–1...
    99+
    2024-01-23
    算法的概念
  • JAVA十大排序算法之归并排序详解
    目录归并排序怎么分怎么治代码实现时间复杂度算法稳定性总结归并排序 归并,指合并,合在一起。归并排序(Merge Sort)是建立在归并操作上的一种排序算法。其主要思想是分而治之。什么...
    99+
    2024-04-02
  • Go归并排序算法的实现方法
    目录归并排序的思想归并排序的 Go 代码实现归并排序的时间复杂度今天继续基础排序算法的图解和Go 代码实现,这次分享一个时间复杂度为*** 诶,时间复杂度多少先保密,文末会有分析。这...
    99+
    2024-04-02
  • C++如何实现归并排序算法
    这篇文章将为大家详细讲解有关C++如何实现归并排序算法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。归并算法开始首先要对一段要有序的数字进行排序void merg_sort(int* ...
    99+
    2023-06-25
  • C++归并排序算法怎么实现
    这篇文章主要介绍“C++归并排序算法怎么实现”,在日常操作中,相信很多人在C++归并排序算法怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++归并排序算法怎么实现”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-06-26
  • Java快速排序与归并排序及基数排序图解示例
    目录一、快速排序1、基本介绍2、代码实现二、归并排序1、基本介绍2、代码实现三、基数排序1、基本介绍2、代码实现一、快速排序 1、基本介绍 以上面的数组为例分析快速排序。 首先要...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作