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
|
#include <stdlib.h>
#include "sorters.h"
#include "common.h"
/* A simple heap sort implementation.. only in-place O(nlogn) sort I know. */
#define MIN(a, b) ((a)<(b) ? (a) : (b))
static void sift(char *base, size_t root, size_t nel, size_t width, int (*cmp)(const void *, const void *))
{
size_t max;
while (2*root <= nel) {
max = 2*root;
if (max < nel && cmp(base+max*width, base+(max+1)*width) < 0)
max++;
if (max && cmp(base+root*width, base+max*width) < 0) {
swap(base+root*width, base+max*width, width);
root = max;
} else break;
}
}
void musl_heapsort(void *_base, size_t nel, size_t width, cmpfun cmp)
{
char *base = _base;
size_t i;
if (!nel) return;
for (i=(nel+1)/2; i; i--)
sift(base, i-1, nel-1, width, cmp);
for (i=nel-1; i; i--) {
swap(base, base+i*width, width);
sift(base, 0, i-1, width, cmp);
}
}
|