Библиотечные функции сортировки и поиска


В библиотеку включены функции для реализации поиска и сортировки структурных данных, размещенных в массивах. Эти функции характеризуются следующим образом:

1) в функции передаются параметры, представляющие характеристики массива – указатель на начало, размер одного структурного элемента данных и число элементов в массиве.

2) передается указатель на пользовательскую функцию, определяющую критерий сравнения структурных объектов.

3) при поиске передается еще указатель на ключевой элемент, который должен быть структурой того же типа, что и в массиве.

Прототипы находятся в файлах stdlib.h или search.h.

Функции lfind() и lsearch() выполняют линейный поиск в массиве, перебирая подряд все элементы.

Их спецификация следующая:

void *lfind(cjnst void *key, const void *base,size_t *phelem, size_t width,

int(*fcmp)(const void * elem 1,cjnst void *elem2))

void * lsearch (/* те же параметры*/

Функция lfind возвращает указатель на найденный элемент или Null, если элемент не найден, то добавляется в массив в конце еще один элемент, на который ссылается параметр key.

Параметры:

key – ссылка на ключевой элемент, это должна быть структура такая же как и в массиве.

base - начальный адрес массива для поиска

phelem - указатель на число элементов в массиве

width - размер одного структурного элемента

fcmp -указатель на пользовательскую функцию, которая должна принимать два параметра, указатель на структурные элементы того же типа что и в массиве.

Она должна возвращать 0 если элементы равны, по критерию сравнения, который пользователь заложил в эту функцию, или любое ненулевое значение в противном случае.

Функции bsearch () и gsort () реализуют, соответственно, бинарный поиск в упорядоченном массиве и сортировку методом Хоара.

Их спецификация следующая:

void * bsearch (/* те же параметры, что у предыдущих функций */)

Результат у bsearch() тот же, что у lfind(). Единственное отличие состоит в том, что функция (*fcmp) () должна возвращать значение меньше нуля, если

*elem1< * elem2, равное нулю, если

*elem1= * elem2, и больше нуля, если

*elem1> * elem2. и снова решение о том, как понимать отношения <, =, > возлагается на функцию пользователя.

void gsort ( void * base, sire_t phelem, size_t width,

int (* fcmp) (const void * elem1, const void * elem2)

То же назначение параметров, но отсутствует указатель на ключевой элемент. pnelem – само значение, а не указатель. Функция (* fcmp)() должна удовлетворять тем же условиям, что у bsearch(). Т.о., эта функция должна быть чуть сложнее, чем аналогичная функция для линейного поиска из-за того, что она должна давать направление для продолжения поиска элемента.



Дата добавления: 2016-05-26; просмотров: 1667;


Поиск по сайту:

Воспользовавшись поиском можно найти нужную информацию на сайте.

Поделитесь с друзьями:

Считаете данную информацию полезной, тогда расскажите друзьям в соц. сетях.
Poznayka.org - Познайка.Орг - 2016-2024 год. Материал предоставляется для ознакомительных и учебных целей.
Генерация страницы за: 0.007 сек.