#include <stdlib.h>
void qsort(void *buf, size_t num, size_t size, int (*compare) (const void *, const void *));
Функция qsort() сортирует массив, адресуемый параметром-указателем buf. (Для сортировки используется алгоритм быстрой сортировки (алгоритм quicksort), разработанный Ч.Э.Р. Хоаром (C.A.R. Hoare). Быстрая сортировка считается наилучшим алгоритмом сортировки общего назначения.) Количество элементов в массиве задается параметром num, а размер (в байтах) каждого элемента — параметром size.
Для сравнения двух элементов массива используется функция, передаваемая через параметр compare. Функция compare должна иметь следующее описание.
int func_name(const void *arg1, const void *arg2);
Она должна возвращать значения, описанные ниже.
Сравнение | Возвращаемое значение |
---|---|
arg1 меньше arg2 | Меньше нуля |
arg1 равен arg2 | Нуль |
arg1 больше arg2 | Больше нуля |
Массив сортируется в порядке возрастания, т.е. по самому младшему адресу будет записан наименьший элемент.
Пример
Следующая программа сортирует список целых чисел и выводит результат:
#include <stdlib.h>
#include <stdio.h>
int num[10] = {
1, 3, 6, 5, 8, 7, 9, 6, 2, 0
};
int comp(const void *, const void *);
int main(void)
{
int i;
printf("Исходный массив: ");
for(i=0; i<10; i++) printf("%d ", num[i]);
qsort(num, 10, sizeof(int), comp);
printf("Отсортированный массив: ");
for(i=0; i<10; i++) printf("%d ", num[i]);
return 0;
}
/* сравнение целых */
int comp(const void *i, const void *j)
{
return *(int *)i - *(int *)j;
}
Зависимые функции
bsearch()
Сортировка в убывающем порядке
Функция-параметр compare фактически определяет порядок, используемый при сортировке. Задавая с ее помощью различные порядки на сортируемом множестве, можно получить различные упорядочения исходного массива. Например, чтобы отсортировать массив в порядке убывания (т.е. от большего к меньшему), необходимо в этой функции определить обратный (т.е. дуальный или двойственный) порядок. Для этого достаточно определить функцию, лишь знаком отличающуюся от исходной. Это можно сделать, например, так: compare1(x,y) = compare(у,х) или так: compare1(х,у) = — compare(х,у).