Provided by: manpages-ru-dev_4.27.0-1_all bug

НАИМЕНОВАНИЕ

       bsearch - выполняет двоичный поиск в упорядоченном массиве

БИБЛИОТЕКА

       Стандартная библиотека языка C (libc, -lc)

ОБЗОР

       #include <stdlib.h>

       void *bsearch(const void key[.size], const void base[.size * .nmemb],
                     size_t nmemb, size_t size,
                     int (*compar)(const void [.size], const void [.size]));

ОПИСАНИЕ

       Функция  bsearch()  ищет в массиве размером nmemb ( base указывает на начальный элемент) элемент, который
       совпадает с элементом, указываемым в key. Размер каждого элемента массива задаётся в size.

       Содержимое массива должно быть отсортировано по возрастанию  с  помощью  функции  сравнения,  на  которую
       ссылается  compar.  Функция  compar  принимает  два аргумента, один указывает на элемент key, а другой на
       элемент массива (в таком порядке), и должна возвращать целое, которое меньше, равно или больше нуля, если
       найденный элемент key меньше, совпадает или больше элемента массива, соответственно.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

       Функция bsearch() возвращает указатель на совпадающий элемент массива или NULL, если ничего  не  найдено.
       Если с ключом совпадает несколько элементов, то какой из них будет возвращён стандартом не определено.

АТРИБУТЫ

       Описание терминов данного раздела смотрите в attributes(7).
       ┌─────────────────────────────────────────────────────────────────────┬──────────────────────┬──────────┐
       │ ИнтерфейсАтрибутЗначение │
       ├─────────────────────────────────────────────────────────────────────┼──────────────────────┼──────────┤
       │ bsearch()                                                           │ Безвредность в нитях │ MT-Safe  │
       └─────────────────────────────────────────────────────────────────────┴──────────────────────┴──────────┘

СТАНДАРТЫ

       C11, POSIX.1-2008.

ИСТОРИЯ

       POSIX.1-2001, C89, C99, SVr4, 4.3BSD.

ПРИМЕРЫ

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

       #include <stdio.h>
       #include <stdlib.h>
       #include <string.h>

       #define ARRAY_SIZE(arr)  (sizeof((arr)) / sizeof((arr)[0]))

       struct mi {
           int         nr;
           const char  *name;
       };

       static struct mi  months[] = {
           { 1, "jan" }, { 2, "feb" }, { 3, "mar" }, { 4, "apr" },
           { 5, "may" }, { 6, "jun" }, { 7, "jul" }, { 8, "aug" },
           { 9, "sep" }, {10, "oct" }, {11, "nov" }, {12, "dec" }
       };

       static int
       compmi(const void *m1, const void *m2)
       {
           const struct mi *mi1 = m1;
           const struct mi *mi2 = m2;

           return strcmp(mi1->name, mi2->name);
       }

       int
       main(int argc, char *argv[])
       {
           qsort(months, ARRAY_SIZE(months), sizeof(months[0]), compmi);
           for (size_t i = 1; i < argc; i++) {
               struct mi key;
               struct mi *res;

               key.name = argv[i];
               res = bsearch(&key, months, ARRAY_SIZE(months),
                             sizeof(months[0]), compmi);
               if (res == NULL)
                   printf("'%s': unknown month\n", argv[i]);
               else
                   printf("%s: month #%d\n", res->name, res->nr);
           }
           exit(EXIT_SUCCESS);
       }

СМОТРИТЕ ТАКЖЕ

       hsearch(3), lsearch(3), qsort(3), tsearch(3)

ПЕРЕВОД

       Русский перевод этой страницы руководства разработал(и) Artyom  Kunyov  <artkun@guitarplayer.ru>,  Azamat
       Hackimov  <azamat.hackimov@gmail.com>,  Dmitriy  Ovchinnikov  <dmitriyxt5@gmail.com>, Dmitry Bolkhovskikh
       <d20052005@yandex.ru>, ITriskTI  <ITriskTI@gmail.com>,  Yuri  Kozlov  <yuray@komyakino.ru>,  Иван  Павлов
       <pavia00@gmail.com> и Kirill Rekhov <krekhov.dev@gmail.com>

       Этот  перевод является свободной программной документацией; он распространяется на условиях общедоступной
       лицензии GNU (GNU General Public License - GPL, https://www.gnu.org/licenses/gpl-3.0.html  версии  3  или
       более поздней) в отношении авторского права, но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ.

       Если  вы  обнаружите какие-либо ошибки в переводе этой страницы руководства, пожалуйста, сообщите об этом
       разработчику(ам)  по  его(их)  адресу(ам)  электронной  почты  или  по   адресу   списка рассылки русских
       переводчиков.

Справочные страницы Linux 6.9.1                  15 июня 2024 г.                                      bsearch(3)