| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 
 | 
 
 
 public class MergeSort1 {
 
 public static int[] mergeSort(int[] arr, int left, int right) {
 
 if (left < right) {
 
 int mid = (left + right) / 2;
 
 arr = mergeSort(arr, left, mid);
 
 arr = mergeSort(arr, mid + 1, right);
 
 merge(arr, left, mid, right);
 }
 return arr;
 }
 
 
 
 public static void merge(int[] arr, int left, int mid, int right) {
 
 int[] a = new int[right - left + 1];
 int i = left;
 int j = mid + 1;
 int k = 0;
 while (i <= mid && j <= right) {
 if (arr[i] < arr[j]) {
 a[k++] = arr[i++];
 } else {
 a[k++] = arr[j++];
 }
 }
 while (i <= mid) {
 a[k++] = arr[i++];
 }
 while (j <= right) {
 a[k++] = arr[j++];
 }
 
 for (i = 0; i < k; i++) {
 arr[left++] = a[i];
 }
 }
 
 public static void main(String[] args) {
 int[] arr = {2, 5, 3, 1, 4, 6};
 mergeSort(arr, 0, arr.length - 1);
 System.out.println(Arrays.toString(arr));
 }
 
 }
 
 |