返回顶部
首页 > 资讯 > 精选 >Java归并排序举例分析
  • 927
分享到

Java归并排序举例分析

2023-06-25 16:06:10 927人浏览 安东尼
摘要

这篇文章主要介绍“Java归并排序举例分析”,在日常操作中,相信很多人在Java归并排序举例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java归并排序举例分析”的疑惑有所帮助!接下来,请跟着小编一起来

这篇文章主要介绍“Java归并排序举例分析”,在日常操作中,相信很多人在Java归并排序举例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java归并排序举例分析”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

归并排序原理

尽可能的一组数据拆分成两个元素相等的子组,并对每一个子组继续拆分,直到拆分后的每个子组的元素个数是1为止。
⒉将相邻的两个子组进行合并成一个有序的大组。
3.不断的重复步骤2,直到最终只有一个组为止。

归并排序api设计

类名Merge
构造方法Merge():创建Merge对象
成员方法

public static void sort(Comparable[] a):对数组内的元素进行排序

private static void sort(Comparable[] a,int lo,int hi):对数组a中从索引lo到索引hi之间的元素进行排序

private static void merge(Comparable[] a,int lo,int mid,int hi):从索引lo到索引mid为一个子组,从索引mid+1到索引hi为另一个子组,把数组a中的这两个子组的数据合并成一个有序的大组(从索引lo到索引hi)

private static boolean less(Comparable v,Comparable w):判断v是否小于w

private static void exchange(Comparable[] a,int i,int j):交换a数组中,索引i和索引j处的值

成员变量private static ComParable[] assit:完成归并操作需要的辅助数组

归并排序代码实现

public class Merge {    //辅助数组    private static Comparable[] assist;    //对数组a中的元素进行排序    public static void sort(Comparable[] a){        assist=new Comparable[a.length];        int lo=0;        int hi=a.length-1;        sort(a,lo,hi);    }    //对数组a中从lo到hi的元素进行排序    private static void sort(Comparable[] a,int lo,int hi){        if(hi<=lo){            return;        }        int mid=lo+(hi-lo)/2;        //对lo到mid之间的元素进行排序        sort(a,lo,mid);        //对mid+1到hi之间的元素进行排序        sort(a,mid+1,hi);        //对lo到mid这组数据和mid到hi这组数据进行归并        merge(a,lo,mid,hi);    }    //对数组中,从lo到mid为一组,从mid+1到hi为一组,对这两组数据进行归并    public static void merge(Comparable[] a,int lo,int mid,int hi){        //lo到mid这组数据和mid+1到hi这组数据归并到辅助数组assist对应的索引处        int i=lo;//定义一个指针,指向assist数组中开始填充数据的索引        int p1=lo;//定义一个指针,指向第一组数据的第一个元素        int p2=mid+1;//定义一个指针,指向第二组数据的第一个元素        //比较左边小组和右边小组中的元素大小,哪个小,就把哪个数据填充到assist数组中        while(p1<=mid&&p2<=hi){            if(less(a[p1],a[p2])){                assist[i++]=a[p1++];            }else{                assist[i++]=a[p2++];            }        }        //把未填充的数据填到assist中        while(p1<=mid){            assist[i++]=a[p1++];        }        while(p2<=hi){            assist[i++]=a[p2++];        }        for(int index=lo;index<=hi;index++){            a[index]=assist[index];        }    }    //比较v元素是否小于w元素    private static boolean less(Comparable v,Comparable w){        return v.compareTo(w)<0;    }    //数组元素i和j交换位置    private static void exchange(Comparable[] a,int i,int j){        Comparable t=a[i];        a[i]=a[j];        a[j]=t;    } }//测试代码 class Test{    public static void main(String[] args) {        Integer[] a={8,4,6,5,7,1,3,6,2};        Merge.sort(a);        System.out.println(Arrays.toString(a));    }}

归并排序的时间复杂度分析

归并排序是分治思想的最典型的例子,上面的算法中,对a[lo..hi]进行排序,先将它分为a[lo..mid]和a[mid+1..hi]两部分,分别通过递归调用将他们单独排序,最后将有序的子数组归并为最终的排序结果。该递归的出口在于如果一个数组不能再被分为两个子数组,那么就会执行merge进行归并,在归并的时候判断元素的大小进行排序。

用树状图来描述归并,如果一个数组有8个元素,那么它将每次除以2找最小的子数组,共拆log8次,值为3,所以树共有3层那么自顶向下第k层有2^k个子数组,每个数组的长度为2^(3-k),归并最多需要2^(3-k)次比较。因此每层的比较次数为2^k * 2^(3-k)=2^3,那么3层总共为3*2^3。

假设元素的个数为n,那么使用归并排序拆分的次数为log2(n).所以共log2(n)层,那么使用log2(n)替换上面3*2^3中的3这个层数,最终得出的归并排序的时间复杂度为︰log2(n)*2^(log2(n))=log2(n)*n,根据大O推导法则,忽略底数,最终归并排序的时间复杂度为O(nlogn);
归并排序的缺点∶
需要申请额外的数组空间,导致空间复杂度提升,是典型的以空间换时间的操作。

到此,关于“Java归并排序举例分析”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: Java归并排序举例分析

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

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

猜你喜欢
  • Java归并排序举例分析
    这篇文章主要介绍“Java归并排序举例分析”,在日常操作中,相信很多人在Java归并排序举例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java归并排序举例分析”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-25
  • Java冒泡排序举例分析
    这篇文章主要讲解了“Java冒泡排序举例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java冒泡排序举例分析”吧!冒泡排序原理①比较相邻的元素,如果前一个元素比后一个元素大,则交换这两...
    99+
    2023-06-25
  • Java选择排序举例分析
    这篇文章主要介绍“Java选择排序举例分析”,在日常操作中,相信很多人在Java选择排序举例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java选择排序举例分析”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-25
  • Java插入排序举例分析
    本篇内容主要讲解“Java插入排序举例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java插入排序举例分析”吧!插入排序原理①把所有元素分成已排序和未排序两组②找到未排序组的第一个元素,向...
    99+
    2023-06-25
  • Java 十大排序算法之归并排序刨析
    目录归并排序原理归并排序API设计归并排序代码实现归并排序的时间复杂度分析归并排序原理 1.尽可能的一组数据拆分成两个元素相等的子组,并对每一个子组继续拆分,直到拆分后的每个子组的元...
    99+
    2024-04-02
  • java 排序算法之归并排序
    目录简单介绍基本思想思路分析代码实现对代码的一些改进大数据量耗时测试复杂度简单介绍 归并排序(merge sort)是利用 归并 的思想实现的排序方法,该算法采用经典的分治(divi...
    99+
    2024-04-02
  • Java 归并排序算法、堆排序算法实例详解
    基本思想:  归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序子序列合并为整体有序序列。归并排序示例:合并方法:设r[i…n]由两个有序子表r[i…m...
    99+
    2023-05-31
    java 归并排序 堆排序
  • Java快速排序与归并排序及基数排序图解示例
    目录一、快速排序1、基本介绍2、代码实现二、归并排序1、基本介绍2、代码实现三、基数排序1、基本介绍2、代码实现一、快速排序 1、基本介绍 以上面的数组为例分析快速排序。 首先要...
    99+
    2024-04-02
  • Java实现归并排序的示例代码
    目录1.算法理解2.实现代码3.实现效果1.算法理解 参考:图解Java中归并排序算法的原理与实现 2.实现代码 import java.lang.reflect.Array; im...
    99+
    2024-04-02
  • 什么是Java归并排序
    本篇内容主要讲解“什么是Java归并排序”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“什么是Java归并排序”吧!基本介绍归并排序(merge-sort)是利用归并的思想实现的排序方法,该算法采...
    99+
    2023-06-15
  • 图解Java排序算法之归并排序
    目录基本思想合并相邻有序子序列代码实现总结基本思想 归并排序(MERGE-SORT)是利用归并的思想实现的排序方法,该算法采用经典的分治(divide-and-conquer)策略(...
    99+
    2024-04-02
  • 20190516-归并排序
    合并两个有序数组中相同的数,输出到一个新的数组中 难度分类 简单 题目描述 合并两个有序数组中相同的数,输出到一个新的数组中 示例1: 输入: nums1 = [1,2,3] nums2 = [2,5,6] 输出: [1,2] 示例2: ...
    99+
    2023-01-31
  • Java实现插入排序,希尔排序和归并排序
    目录插入排序算法步骤动图演示JavaScript代码实现Python代码实现Go代码实现Java代码实现希尔排序算法步骤JavaScript代码实现python代码实现Go代码实现J...
    99+
    2022-12-22
    Java插入排序 Java希尔排序 Java归并排序 Java排序
  • Java综合整理堆排序 快速排序 归并排序
    目录堆排序快速排序递归非递归归并排序递归非递归堆排序 时间复杂度:0(N*log(N))空间复杂度:0(1)稳定性:不稳定 private static void heapSort...
    99+
    2024-04-02
  • Java的堆排序、快速排序、归并排序怎么实现
    本文小编为大家详细介绍“Java的堆排序、快速排序、归并排序怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java的堆排序、快速排序、归并排序怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。堆排序...
    99+
    2023-06-26
  • JAVA十大排序算法之归并排序详解
    目录归并排序怎么分怎么治代码实现时间复杂度算法稳定性总结归并排序 归并,指合并,合在一起。归并排序(Merge Sort)是建立在归并操作上的一种排序算法。其主要思想是分而治之。什么...
    99+
    2024-04-02
  • Java排序算法之归并排序简单实现
    算法描述:对于给定的一组记录,首先将每两个相邻的长度为1的子序列进行归并,得到 n/2(向上取整)个长度为2或1的有序子序列,再将其两两归并,反复执行此过程,直到得到一个有序序列。package sorting;public class M...
    99+
    2023-05-30
    java算法 归并排序 ava
  • Java归并排序和快速排序怎么实现
    本篇内容介绍了“Java归并排序和快速排序怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!归并排序// 归并排序 ...
    99+
    2023-06-04
  • java 基本算法之归并排序实例代码
    java 基本算法之归并排序实例代码原理:归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,     * 即把待排序序列分为若干个子序列,每个子序列是有序的。 &nb...
    99+
    2023-05-31
    java 归并排序 ava
  • Java归并排序代码怎么写
    本篇内容主要讲解“Java归并排序代码怎么写”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java归并排序代码怎么写”吧!归并排序(Merge)是将两个(或两个以上)有序表合并成一个新的有序表,...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作