public class MergeSort {
public static void mergeSort(int[] a, int n) {
mergeSortInternally(a, 0, n - 1);
}
private static void mergeSortInternally(int[] a, int p, int r) {
if (p >= r) return;
int q = p + (r - p) / 2;
mergeSortInternally(a, p, q);
mergeSortInternally(a, q + 1, r);
merge(a, p, q, r);
}
private static void merge(int[] a, int p, int q, int r) {
int i = p;
int j = q + 1;
int k = 0;
int[] tmp = new int[r - p + 1];
while (i <= q && j <= r) {
if (a[i] <= a[j]) {
tmp[k++] = a[i++];
} else {
tmp[k++] = a[j++];
}
}
int start = i;
int end = q;
if (j <= r) {
start = j;
end = r;
}
while (start <= end) {
tmp[k++] = a[start++];
}
for (i = 0; i <= r - p; ++i) {
a[p + i] = tmp[i];
}
}
public static void main(String[] args) {
int[] a = new int[6];
a[0] = 6;
a[1] = 5;
a[2] = 4;
a[3] = 2;
a[4] = 3;
a[5] = 1;
MergeSort.mergeSort(a,6);
for (int i = 0; i < a.length; i++) {
System.out.println(a[i]);
}
}
}