-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMarge_Sort.c
69 lines (51 loc) · 1.33 KB
/
Marge_Sort.c
1
2
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#include <stdio.h>
#include <stdlib.h>
void merge(short a[], short t[], int ls, int m, int re) {
int le = m - 1;
int tp = ls;
int num = re - ls + 1;
while (ls <= le && m <= re) {
if (a[ls] <= a[m])
t[tp++] = a[ls++];
else
t[tp++] = a[m++];
}
while (ls <= le)
t[tp++] = a[ls++];
while (m <= re)
t[tp++] = a[m++];
for (int i = 0; i < num; i++, re--)
a[re] = t[re];
}
void mergeSortHelper(short a[], short t[], int l, int r) {
if (l >= r)
return;
int m = (l + r) / 2;
mergeSortHelper(a, t, l, m);
mergeSortHelper(a, t, m + 1, r);
merge(a, t, l, m + 1, r);
}
void mergeSort(short a[], int s) {
short* t = (short*)malloc(s * sizeof(short));
mergeSortHelper(a, t, 0, s - 1);
free(t);
}
int main() {
int s;
short* a;
printf("Enter the size of the array: ");
scanf("%d", &s);
a = (short*)malloc(s * sizeof(short));
printf("Enter %d elements:\n", s);
for (int i = 0; i < s; i++) {
printf("Element %d: ", i + 1);
scanf("%hd", &a[i]);
}
mergeSort(a, s);
printf("\nSorted array: ");
for (int i = 0; i < s; i++)
printf("%hd ", a[i]);
free(a);
return 0;
}
//complexity : O(nLogn)