一、归并排序学习
归并排序用到了“分治法”这种设计方法。
分治法步骤
1、分解,原问题分解为若干子问题
2、递归解决
3、合并
归并排序的步骤:
1、分解,待排序的n个元素的序列各分为n/2个元素的子序列
2、解决,使用归并排序递归地排序两个子序列
3、合并,合并两个已经排序的子序列以产生排序的答案
伪代码:
//MERGE-SORT(A,p,r)对数组A[p,r]排序
动态过程理解:
JAVA实现:
public class Merge
{
private static Comparable[] aux; // auxiliary array for merges
public static void sort(Comparable[] a)
{
aux = new Comparable[a.length]; // Allocate space just once.
sort(a, 0, a.length - 1);
}
private static void sort(Comparable[] a, int lo, int hi)
{ // Sort a[lo..hi].
if (hi <= lo) return;
int mid = lo + (hi - lo)/2;
sort(a, lo, mid); // Sort left half.
sort(a, mid+1, hi); // Sort right half.
merge(a, lo, mid, hi); // Merge results (code on page 271).
}
public static void merge(Comparable[] a, int lo, int mid, int hi)
{ // Merge a[lo..mid] with a[mid+1..hi].
int i = lo, j = mid+1;
for (int k = lo; k <= hi; k++) // Copy a[lo..hi] to aux[lo..hi].
aux[k] = a[k];
for (int k = lo; k <= hi; k++) // Merge back to a[lo..hi].
if (i > mid) a[k] = aux[j++];
else if (j > hi ) a[k] = aux[i++];
else if (less(aux[j], aux[i])) a[k] = aux[j++];
else a[k] = aux[i++];
}
}