Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  4 627

•  TDictionary Custom Sort  6 627

•  Fast Watermark Sources  6 407

•  3D Designer  9 351

•  Sik Screen Capture  6 739

•  Patch Maker  7 126

•  Айболит (remote control)  7 133

•  ListBox Drag & Drop  5 991

•  Доска для игры Реверси  97 571

•  Графические эффекты  7 324

•  Рисование по маске  6 611

•  Перетаскивание изображений  5 485

•  Canvas Drawing  5 860

•  Рисование Луны  5 583

•  Поворот изображения  5 093

•  Рисование стержней  3 659

•  Paint on Shape  2 892

•  Генератор кроссвордов  3 790

•  Головоломка Paletto  3 044

•  Теорема Монжа об окружностях  3 855

•  Пазл Numbrix  2 536

•  Заборы и коммивояжеры  3 248

•  Игра HIP  2 216

•  Игра Go (Го)  2 149

•  Симулятор лифта  2 529

•  Программа укладки плитки  2 170

•  Генератор лабиринта  2 667

•  Проверка числового ввода  2 320

•  HEX View  2 653

•  Физический маятник  2 284

 
скрыть

  Форум  

Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Delphi Sources

Бинарный поиск в целочисленном массиве



Автор: Mystic

{ **** UBPFD *********** by delphibase.endimus.com ****
>> Бинарный поиск

Бинарный поиск в целочисленном массиве - шаблон для функции,
выполняющей бинарный поиск.
X - значение, которое ищеться
A - массив в котором происходит поиск.
возвращаемое значение
индекс элемента, начиная с которого значения в массиве превышают заданное значение
в случае точного поиска заменить строку Result := L и -1 будет свидетельствовать
о том, что значение не найдено.

Зависимости: System
Автор:       Mystic, mystic2000@newmail.ru, ICQ:125905046, Харьков
Copyright:   Mystic
Дата:        25 апреля 2002 г.
***************************************************** }

function BinaryFind(X: Integer; A: array of Integer): Integer;

  function RecurceFind(L, R: Integer): Integer;
  var
    M: Integer;
  begin
    if R < L then
    begin
      Result := L; // Result := -1 если поиск точный
      Exit;
    end;
    M := (L + R) div 2;
    if A[M] = X then
    begin
      Result := M;
      Exit;
    end;
    if A[M] > X then
      Result := RecurceFind(L, M - 1)
    else
      Result := RecurceFind(M + 1, R)
  end;

begin
  Result := RecurceFind(Low(A), High(A));
end;




Похожие по теме исходники

Поисковик

Поиск символа

Поиск файлов

Поиск открытых файлов

 

Findup (поиск дублей)

Дейкстра: поиск кратчайшего пути