[url] http://baike.baidu.com/view/90797.htm[/url]
归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序子序列合并为整体有序序列。
归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。
将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为2-路归并。
算法描述
归并操作的工作原理如下:
申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列
设定两个指针,最初位置分别为两个已经排序序列的起始位置
比较两个指针所指向的元素,选择相对小的元素放入到合并空间,并移动指针到下一位置
重复步骤3直到某一指针达到序列尾
将另一序列剩下的所有元素直接复制到合并序列尾
/**
* @author lgli
*
*/
public class MergeSortTest
{
/**
* @param args
*/
public static void main(String[] args)
{
int[] data =
{ 1, 15, 24, 26, 58, 45, 14, 15, 14, 74 };
mergeSort(data,0, data.length-1);
for (int i = 0; i < data.length; i++)
{
System.out.println(data[i]);
}
// int[] sortData1 =
// { 1, 55, 66, 130 };
// int[] sortData2 =
// { 10, 15, 23, 200 };
// int[] merge = mergeSort1(sortData1, sortData2);
// for (int i = 0; i < merge.length; i++)
// {
// System.out.println(merge[i]);
// }
}
private static void mergeSort(int[] data,int low,int high)
{
if (low<high)
{
mergeSort(data,low,(low+high)/2);
mergeSort(data,(low+high)/2+1,high);
merge(data,low,(low+high)/2,high);
}
}
private static void merge(int[] data,int low,int mid,int high)
{
int[] sortedData=new int[high-low+1];
int tempLow=low;
int tempMid=mid+1;
int index=0;
for ( ; tempLow <= mid&&tempMid<=high;)
{
if (data[tempLow] <= data[tempMid])
{
sortedData[index++]=data[tempLow++];
}else
{
sortedData[index++]=data[tempMid++];
}
}
while (tempLow <= mid)
{
sortedData[index++] = data[tempLow++];
}
while (tempMid <= high)
{
sortedData[index++] = data[tempMid++];
}
for (int i = 0; i < sortedData.length; i++)
{
data[low+i]=sortedData[i];
}
}
public static int[] mergeSort1(int[] sortData1, int[] sortData2)
{
int[] temp = new int[sortData1.length + sortData2.length];
int i = 0, j = 0, iter = 0;
for (; i < sortData1.length && j < sortData2.length;)
{
if (sortData1[i] <= sortData2[j])
{
temp[iter] = sortData1[i];
iter++;
i++;
}
else
{
temp[iter] = sortData2[j];
iter++;
j++;
}
}
for (; i < sortData1.length; i++, iter++)
{
temp[iter] = sortData1[i];
}
for (; j < sortData2.length; j++, iter++)
{
temp[iter] = sortData2[j];
}
return temp;
}
}
分享到:
相关推荐
归并排序是一种高效的排序算法,基于分治策略。在Java中实现归并排序,我们可以创建一个名为`MergeSort`的类来封装整个过程。归并排序的基本思想是将待排序的序列分成两个或更多的子序列,对每个子序列分别进行排序...
【归并排序】是一种高效的排序算法,其基本思想源于分治法(Divide and Conquer)。归并排序通过不断地将数组划分为较小的子序列,然后对这些子序列进行排序,最后将排序好的子序列合并成一个完整的有序序列。在这个...
### 归并排序算法实现详解 #### 一、引言 归并排序是一种经典的排序算法,采用分治法的思想,将待排序数组分为若干个子序列,这些子序列是已排序的,然后再按照一定的方式合并这些子序列得到最终排序后的数组。...
C#排序算法之归并排序 C#排序算法之归并排序是一种基于分治策略的排序算法,通过将数组分割成两个子数组,递归地对每个子数组进行排序,然后将两个有序的子数组合并成一个有序的数组。下面是对C#实现归并排序的详细...
本文实例为大家分享了C语言实现归并排序的具体代码,供大家参考,具体内容如下 归并排序的基本思想: 将两个及其以上的有序表合并为一张有序表,把待排序序列通过分治法分为若干个有序子序列,然后每两个子序列合并...
归并排序是一种高效的、稳定的排序算法,其核心思想是“分而治之”。在Python中实现归并排序,我们可以分为以下几个步骤来理解: 1. **分割**:首先,我们需要将原始数组不断地分成两半,直到每个子数组只剩下一个...
归并排序是一种高效的排序算法,基于分治策略。在C#中,归并排序可以通过递归、非递归以及自然归并三种方式实现。以下是这三种实现方法的详细解释: 1. **递归归并排序**: 递归归并排序是归并排序最直观的实现...
归并排序(Merge Sort)是一种基于分治策略的高效排序算法。它的基本思想是将待排序的序列分为两部分,分别对这两部分进行排序,然后将排好序的子序列合并成一个完整的有序序列。这一过程可以递归地进行,直到每个子...
**三路归并排序**是一种高效的排序算法,尤其在处理含有大量重复元素的序列时表现优秀。该算法基于归并排序的思想,但将其分为三个部分处理,而不是传统的两个部分。在本文中,我们将深入探讨三路归并排序的原理、...
归并排序是一种分治策略的排序算法,它的基本思想是将大问题分解成小问题来解决。在归并排序中,我们将一个大数组分成两个或更多个小数组,然后对每个小数组进行排序,最后将这些小数组合并成一个大的有序数组。这个...
归并排序是一种基于分治策略的高效排序算法,它的核心思想是将大问题分解成小问题,然后分别解决小问题,最后将小问题的结果合并,得到大问题的解。在这个过程中,归并排序将待排序的序列不断地分成两半,直到每个子...
归并排序是一种基于分治策略的高效排序算法,它的核心思想是将大问题分解成小问题,逐个解决,然后再将结果合并,最终得到整个问题的解决方案。在归并排序中,这一过程主要分为三个步骤:分解、求解和组合。 1. **...
归并排序(MERGE-SORT)是利用归并的思想实现的排序方法,该算法采用经典的分治(divide-and-conquer)策略(分治法将问题分(divide)成一些小的问题然后递归求解,而治(conquer)的阶段则将分的阶段得到的各答案"...
归并排序(Merge Sort)是一种经典的分治算法,它将一个数组分成两个子数组,分别对这两个子数组进行排序,然后再将两个已排序的子数组合并成一个完整的有序数组。压缩包文件代码是一个使用JavaScript实现归并排序的...
1,归并排序的概念 1.1,算法介绍 和选择排序一样,归并排序的性能不受输入数据的影响,但表现比选择排序好的多,因为始终都是O(n log n)的时间复杂度。代价是需要额外的内存空间。归并排序是建立在归并操作上的一...
归并排序(Merge Sort)是一种基于分治策略的高效排序算法。它的基本思想是将待排序的元素序列分成两个或更多的子序列,分别对每个子序列进行排序,然后将排好序的子序列合并成一个有序序列。这个过程可以递归进行,...
归并排序是一种基于分治思想的高效排序算法,它的主要特点是将大问题分解为小问题来解决。在Java中实现归并排序,我们可以分别实现递归版和非递归版,这两种方法各有其特点和适用场景。 ### 1. 分治策略 归并排序...
内部排序之归并排序的代码实现,代码风格简单 易于看懂
本文将详细介绍C++中实现的希尔排序、快速排序、堆排序和归并排序这四种经典排序算法。 希尔排序,由Donald Shell于1959年提出,是一种改进的插入排序。它的基本思想是通过设置一个增量序列,将待排序的元素按照...