2

Run Settings
LanguageC
Language Version
Run Command
Program: #include <stdio.h> #include <stdlib.h> #include <time.h> void merge(int arr[], int l, int m, int r) { int i, j, k; int n1 = m - l + 1; int n2 = r - m; int L[n1], R[n2]; for (i = 0; i < n1; i++) { L[i] = arr[l + i]; } for (j = 0; j < n2; j++) { R[j] = arr[m + 1 + j]; } i = 0; j = 0; k = l; while (i < n1 && j < n2) { if (L[i] <= R[j]) { arr[k] = L[i]; i++; } else { arr[k] = R[j]; j++; } k++; } while (i < n1) { arr[k] = L[i]; i++; k++; } while (j < n2) { arr[k] = R[j]; j++; k++; } } void mergeSort(int arr[], int l, int r) { if (l < r) { int m = l + (r - l) / 2; mergeSort(arr, l, m); mergeSort(arr, m + 1, r); merge(arr, l, m, r); } } int main() { int arr[10000]; int i, n; printf("Enter the size of the array: "); scanf("%d", &n); printf("Enter the elements of the array:\n"); for (i = 0; i < n; i++) { scanf("%d", &arr[i]); } clock_t start, end; double cpu_time_used; start = clock(); mergeSort(arr, 0, n - 1); end = clock(); cpu_time_used = ((double) (end - start)) / CLOCKS_PER_SEC; printf("\nRunning time: %f seconds\n", cpu_time_used); printf("Sorted array:\n"); for (i = 0; i < n; i++) { printf("%d ", arr[i]); } return 0; } Output: Enter the size of the array: 10 Enter the elements of the array: 23 12 8 20 34 47 92 61 72 52 Running time: 0.000002 seconds Sorted array: 8 12 20 23 34 47 52 61 72 92
Editor Settings
Theme
Key bindings
Full width
Lines