-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy path103-merge_sort.c
More file actions
105 lines (93 loc) · 1.75 KB
/
103-merge_sort.c
File metadata and controls
105 lines (93 loc) · 1.75 KB
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
#include "sort.h"
#include <stdio.h>
/**
* print_data - print data
* @msg: message
* @a: array
* @from: from
* @to: to
* Return: no return
*/
void print_data(char *msg, int *a, int from, int to)
{
char *sep;
int i;
printf("[%s]: ", msg);
sep = "";
for (i = from; i <= to; i++)
{
printf("%s%d", sep, a[i]);
sep = ", ";
}
printf("\n");
}
/**
* merge - Auxiliar function for
* Merge sort algorithm
* @a: array
* @low: low index
* @middle: middle
* @high: high index
* @buff: buffer
* Return: no return
*/
void merge(int *a, int low, int middle, int high, int *buff)
{
int lo, lm, i;
lo = i = low;
lm = middle + 1;
printf("Merging...\n");
print_data("left", a, low, middle);
print_data("right", a, middle + 1, high);
while (lo <= middle && lm <= high)
{
if (a[lo] < a[lm])
buff[i++] = a[lo++];
else
buff[i++] = a[lm++];
}
while (lo <= middle)
buff[i++] = a[lo++];
while (lm <= high)
buff[i++] = a[lm++];
for (i = low; i <= high; i++)
a[i] = buff[i];
print_data("Done", a, low, high);
}
/**
* msort -Auxiliar function for
* Merge sort algorithm
* @array: array
* @low: low index
* @high: high index
* @buffer: buffer
* Return: no return
*/
void msort(int *array, int low, int high, int *buffer)
{
int midle;
if (low < high)
{
midle = (low + high - 1) / 2;
msort(array, low, midle, buffer);
msort(array, midle + 1, high, buffer);
merge(array, low, midle, high, buffer);
}
}
/**
* merge_sort -Sorts an arrayof integers
* in ascending order using the
* Merge sort algorithm
* @array: array
* @size: size
* Return: no return
*/
void merge_sort(int *array, size_t size)
{
int *buffer;
buffer = malloc(sizeof(int) * size);
if (!buffer)
return;
msort(array, 0, size - 1, buffer);
free(buffer);
}