MergeSort 歸併排序 排序思想:1,分解待排序的n個元素爲兩個子列,各爲n/2個元素 2,若子列沒有排好序,重複1步驟,每一個子列繼續分解爲兩個子列,直至被分解的子列個數爲1 3,子列元素個數爲1,說明這個子列已經排好序,開始逐級合併子序列進行排序 該算法須要合併分解的子序列,因此須要額外一個輔助過程Merge(A,p,q,r)來完成兩個子列的合併,A爲數組,p,q,r爲數組下標,其中A[p,q]和A[q+1,r]爲兩個已經排好序的子序列,∞表明哨兵值。 Merge僞代碼: Merge(A,p,q,r) n1 = q - p + 1 n2 = r - q let L[1..n1+1] and R[1..n2+1] be new arrays for i = 1 to n1 L[i] = A[p+i-1] for j = 1 to n2 R[j] = a[q+j] L[n1+1] = ∞ R[n2+1] = ∞ i = 1 j = 1 for k = p to r if L[i] <=R[j] A[k] = L[i] i = i + 1 else A[k] = R[j] j = j + 1 MergeSort(歸併排序)僞代碼: MergeSort(A,p,r) if p < r q = (p+r)/2 MergeSort(A,p,q) MergeSort(A,q+1,r) Merge(A,p,q,r)
public class MergeSort{ public static void main(String[] args) { int A[] = { 1,6,4,5,2,9,7,23,56,43,98,56 }; int[] temp = new int[A.length]; MergeSort(A,temp,0,A.length-1); for (int i:A){ System.out.print(i+" "); } } public static void MergeSort(int[] A,int[] temp,int start,int end){ if (start<end){ int mid = (start+end)/2; //把數組分解爲兩個子列 MergeSort(A,temp,start,mid); MergeSort(A,temp,mid+1,end); //逐級合併兩個子列 Merge(A,temp,start,mid,end); } } public static void Merge(int[] A,int[] temp,int start,int mid,int end){ int i = start; int j = mid+1; int k = 0; while(i<=mid&&j<=end){ if (A[i]<=A[j]) { temp[k] = A[i]; i++; k++; }else { temp[k] = A[j]; j++; k++; } } while(i<=mid){ temp[k] = A[i]; k++; i++; } while(j <= end){ temp[k] = A[j]; k++; j++; } for (int m = 0; m<k; m++) { A[start+m] = temp[m]; } } }