【DS】排序算法之归并排序(Merge Sort)
一、算法思想
归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法的一个非常典型的应用,指的是将两个已经排序的序列合并成一个序列的操作。其归并思想如下:
1)申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列;
2)设定两个指针,最初位置分别为两个已经排序序列的起始位置;
3)比较两个指针所指向的元素,选择相对小的元素放入到合并空间,并移动指针到下一位置;
4)重复步骤3直到某一指针达到序列尾;
5)将另一序列剩下的所有元素直接复制到合并序列尾;
在使用归并排序算法的时候,算法如下:
1)将序列切分,直至切分到序列是有序的(这里通过将序列切分成单个元素达到目的);
2)将序列块两两归并成较大的序列块;
3)将较大的序列块再度归并,不断继续,直至归并形成和原始序列同样大小的序列;
二、算法示意图
如图所示,首先第一行表示待排序的序列,第一步就是将序列元素切割为一个个的独立元素(表示有序序列),接着将相邻的两个元素按照归并思想合并成第二行,同样颜色的元素属于一组,接着再次归并,形成第三行的样子。接着将两组归并,就可以形成最后一行已经排好序的样子。
三、Java代码
public class MergeSort extends Sort {
public static void sort(int[] array) {
int[] tempArray = new int[array.length];
mergeSort(array, tempArray, 0, array.length - 1);
printArray(array);
} private static void mergeSort(int[] array, int[] tempArray, int left, int right ) {
if ( left < right ) {
int center = ( left + right ) / 2;
mergeSort(array, tempArray, left, center);
mergeSort(array, tempArray, center + 1, right);
merge(array, tempArray, left, center + 1, right);
}
} private static void merge( int[] array, int[] tempArray, int left, int right, int end) {
int tempLeft = left;
int tempRight = right;
int position = left; while(tempLeft < right && tempRight <= end){//两个队列都没到头
if(array[tempLeft] < array[tempRight])
tempArray[position++] = array[tempLeft++];
else
tempArray[position++] = array[tempRight++];
} while(tempLeft < right){
tempArray[position++] = array[tempLeft++];
} while(tempRight <= end){
tempArray[position++] = array[tempRight++];
} for(int index = left; index <= end; index++){//复制回去
array[index] = tempArray[index];
}
}
}
算法的精华在于函数mergeSort,这是一个递归算法,从第9行可以看出来,数组首先被切成单个单个的元素,然后再归并。第11~13行首先对左半部分进行归并排序,然后对右半部分进行归并排序,最后整体归并。
四、算法复杂度
这里的分析和快速排序一致,同时,由于它是均分,不会出现和快速排序那样分裂开来的序列不均匀导致的性能差异。我们由函数mergeSort可知,T(n)=O(nlogn)。
由上面的实现代码可知,其空间复杂度为O(n)。我们只需要一个临时数组在合并的时候保存数据即可。
【DS】排序算法之归并排序(Merge Sort)的更多相关文章
- 经典排序算法 - 归并排序Merge sort
经典排序算法 - 归并排序Merge sort 原理,把原始数组分成若干子数组,对每个子数组进行排序, 继续把子数组与子数组合并,合并后仍然有序,直到所有合并完,形成有序的数组 举例 无序数组[6 2 ...
- 排序算法二:归并排序(Merge sort)
归并排序(Merge sort)用到了分治思想,即分-治-合三步,算法平均时间复杂度是O(nlgn). (一)算法实现 private void merge_sort(int[] array, int ...
- 连续线性空间排序 起泡排序(bubble sort),归并排序(merge sort)
连续线性空间排序 起泡排序(bubble sort),归并排序(merge sort) 1,起泡排序(bubble sort),大致有三种算法 基本版,全扫描. 提前终止版,如果发现前区里没有发生交换 ...
- Java常见排序算法之归并排序
在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ...
- java排序算法之冒泡排序(Bubble Sort)
java排序算法之冒泡排序(Bubble Sort) 原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一趟:首先比较第1个和第2个数 ...
- 排序算法:归并排序(Merge Sort)
归并排序 归并排序采用了分治策略(divide-and-conquer),就是将原问题分解为一些规模较小的相似子问题,然后递归解决这些子问题,最后合并其结果作为原问题的解. 归并排序将排序数组A[1. ...
- 【排序算法】归并排序算法 Java实现
归并排序是建立在归并操作上的一种有效的排序算法.该算法是采用分治法(Divide and Conquer)的一个非常典型的应用. 基本思想 可以将一组数组分成A,B两组 依次类推,当分出来的小组只有一 ...
- STL 源代码剖析 算法 stl_algo.h -- merge sort
本文为senlie原创.转载请保留此地址:http://blog.csdn.net/zhengsenlie merge sort ----------------------------------- ...
- 我的Java开发学习之旅------>Java经典排序算法之归并排序
一.归并排序 归并排序是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用.将已有序的子序列合并,得到完全有序的序列:即先使每个子序列 ...
随机推荐
- 按键精灵对APP自动化测试(下)
上一篇介绍了安卓app上使用按键精灵的实践,这里再来说说苹果上的app. 由于iOS相关工具对操作系统的限制,目前在iOS10.0.2系统上应用成功. 二. 苹果手机按键精灵APP录制 适 ...
- 3Sum(or k_Sum)
Given an array nums of n integers, are there elements a, b, c in nums such that a + b + c = 0? Find ...
- 分布式理论:深入浅出Paxos算法
前言 Paxos算法是用来解决分布式系统中,如何就某个值达成一致的算法.它晦涩难懂的程度完全可以跟它的重要程度相匹敌.目前关于paxos算法的介绍已经非常多,但大多数是和稀泥式的人云亦云,却很少有人能 ...
- 使用tensorflow实现mnist手写识别(单层神经网络实现)
import tensorflow as tf import tensorflow.examples.tutorials.mnist.input_data as input_data import n ...
- 获取apk的签名信息
在接入第三方功能时,经常要注册提交apk的签名信息 (sha1签名)?,下面列出相关步骤. 获取apk签名信息的步骤: 1)修改apk后缀名为zip,解压得到其中的META-INF文件夹; 2)把ME ...
- Activiti随着Spring启动自动部署开关
Activiti的act_re_deployment表NAME_列:全部显示SpringAutoDeployment. 查阅Activiti,https://github.com/Activiti/A ...
- python文本替换
file_data = '' str1 = ' str2 = ' with open(loginfofile, 'r+') as f: #打开文件,r+模式,读取 for line in f: if ...
- ThreadLocal变量
什么是ThreadLocal变量?ThreadLocal,很多地方叫做线程本地变量,也有些地方叫做线程本地存储,其实意思差不多.可能很多朋友都知道ThreadLocal为变量在每个线程中都创建了一个副 ...
- 通过.json()将服务器返回的字符串转换成字典
- Linux_MySql_tar_安装(转)
系统版本:CentOs 7.* Mysql版本:5.7.17(自己测试版本) 根据博主[大大的橙子]博文转载记录(大部分照搬了,只修改少许部分) 一.基本环境部署 #卸载系统自带的Mariadb [r ...