【排序算法】归并排序算法原理

概念

  归并排序是建立在归并操作上的一种有效的排序算法。

   该算法是采用分治法的一个非常典型的应用。

   将已有序的子序列合并,得到完全有序的序列;

  即先使每个子序列有序,再使子序列段间有序。

  若将两个有序表合并成一个有序表,称为2-路归并。

使用前提

  有序子列的归并

  • 假设有三个表A 、B、C,将有序表A、B插入到C中

  • 设置三个指针(并非必须为指针,可以是任何可以指定位置的结构)Aptr、Bptr、Cptr分别指向A、B、C表的起始位置

  • 比较Aptr和Bptr将大的将其放置到Cptr的位置,然后将改变的+1

  • 代码
    在这里插入图片描述

  • A为待排序数组(A、B),TmpA为排序结果临时存放数组(C),L为左边起始位置(Aptr),R右边的起始位置(Bptr),REnd(右边数组的长度,左边的可以计算)

算法思路

在这里插入图片描述
  归并排序是将两个或两个以上的有序表合并成一个新的有序表

  将已有序的子序列合并,得到完全有序的序列;

即先使每个子序列有序,再使子序列段间有序。

适用场景

  归并排序在数据量比较大的时候也有较为出色的表现(效率上),但是,其空间复杂度O(n)使得在数据量特别大的时候(例如,1千万数据)几乎不可接受。

  而且,考虑到有的机器内存本身就比较小,因此,采用归并排序一定要注意。

算法描述

递归法(Top-down)

分而治之

  分而治之是一种使用递归解决问题的算法,主要的技巧是将一个大的复杂的问题划分为多个子问题,而这些子问题可以作为终止条件,或者在一个递归步骤中得到解决,所有子问题的解决结合起来就构成了对原问题的解决

原理如下(假设序列共有n个元素):

  申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列

   设定两个指针,最初位置分别为两个已经排序序列的起始位置

  比较两个指针所指向的元素,选择相对小的元素放入到合并空间,并移动指针到下一位置

  重复步骤3直到某一指针到达序列尾

  将另一序列剩下的所有元素直接复制到合并序列尾

伪码描述

  生成临时存放空间,并向递归算法传入长度
在这里插入图片描述
  递归算法:每次分半归并到临时数组,然后将临时数组写回待排数组
在这里插入图片描述

迭代法(Bottom-up)

迭代

  将待排序列A进行不断的归并,归并结果存放在A与临时数组TmpA中(如果每次迭代都开辟临时数组将会造成巨大的空间占用),最后将排好序的结果返回在A中即可

原理如下(假设序列共有n个元素):
在这里插入图片描述
**  将序列每相邻两个数字进行归并操作,形成ceil(n/2)个序列,排序后每个序列包含两/一个元素
在这里插入图片描述
**  若此时序列数不是1个则将上述序列再次归并,形成ceil(n/4)个序列,每个序列包含四/三个元素
在这里插入图片描述
**  重复步骤2,直到所有元素排序完毕,即序列数为1
在这里插入图片描述
伪码描述

总控算法:控制迭代算法的执行
在这里插入图片描述
迭代算法
在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Java排序算法是用于对一系列数据进行排列顺序的一种算法。在Java中,常见的排序算法包括冒泡排序、选择排序、插入排序、快速排序、归并排序等。 冒泡排序是一种比较简单的排序算法,它通过对相邻的元素进行比较和交换来实现排序。该算法的时间复杂度为O(n^2),属于比较低效的排序算法。选择排序是一种简单直观的排序算法,它通过选择最小的元素并放置在已排序的部分来实现排序。该算法的时间复杂度也是O(n^2)。 插入排序是一种比较高效的排序算法,它通过将未排序的元素插入到已排序的部分来实现排序。该算法的时间复杂度也是O(n^2)。快速排序是一种递归的排序算法,它通过选取一个基准值来对数组进行分区,并对每个分区进行排序来实现最终的排序。该算法的时间复杂度为O(nlogn),是比较高效的排序算法之一。 归并排序是一种分治的排序算法,它将数组分成两个子数组,并对每个子数组进行排序,最后将两个子数组合并成一个有序数组。该算法的时间复杂度也是O(nlogn)。在实际应用中,我们通常会选择合适的排序算法来应对不同的排序需求,比如对于小规模数据可以选择简单的排序算法,对于大规模数据可以选择高效的排序算法。总之,了解Java排序算法原理和性能表现对于编程人员来说是非常重要的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

列队猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值