Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Бинарный поиск





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

Исполнитель данного алгоритма — человек, имеющий две руки, умеющий читать и сравнивать два слова на предмет, какое из них раньше стоит в словаре. Итак, алгоритм:

1. Если в словаре больше одного разворота страниц, то открыть словарь примерно посередине, иначе перейти на шаг 6.

2. Сравнить самое первое слово на развороте с искомым словом.

3. Если искомое слово стоит раньше, чем первое слово на развороте, то заложить рукой открытую страницу и часть словаря от начала до заложенной страницы считать новым словарем. Перейти к шагу 1.

4. Если искомое слово стоит позже, чем первое слово на развороте, то сравнить последнее слово на развороте с искомым словом.

5. Если искомое слово стоит позже, чем последнее слово на развороте, то заложить рукой открытую страницу и часть словаря от заложенной страницы до конца считать новым словарем. Перейти к шагу 1.

6. Просмотреть все от первого до последнего слова на развороте. Если искомое слово найдено – алгоритм окончен успешно, иначе – искомого слова в словаре нет.

Скачать текст программы

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

Заметим, что даже если данные упорядочены, то использовать алгоритм бинарного поиска мы можем не всегда. Это касается тех случаев, когда мы не имеем доступа к любому элементу массива. Например, если данные поступают к нам последовательно.

Задача Бинарный поиск Последовательный поиск
Мы по телефону получаем количество проголосовавших на каждом участке, и нам надо найти участок, на котором проголосовало N человек НЕТ ДА
Человек ищет нужный ему номер дома на улице НЕТ ДА
В словаре ищем перевод нужного слова ДА НЕТ

Основная идея бинарного поиска довольно проста, но детали нетривиальны, и правильно написать работающий алгоритм удается далеко не с первого раза. В одной из наиболее популярных реализаций этого алгоритма используется два указателя (l и u), соответствующих нижней и верхней границам поиска. С помощью этого алгоритма ищется элемент k в упорядоченном по возрастанию массиве a, содержащем n элементов:

1. Начальная установка l = 1, u = n.

2. Если u < l, то алгоритм окончен неудачно, иначе найти середину интервала [l; u]. В этот момент мы знаем, что если k есть в массиве, то выполняются неравенства al ≤ k ≤ au. Установить i = [(l + u) / 2]. Теперь i указывает примерно на середину рассматриваемой части массива.

3. Если k > ai, то перейти к шагу 4, если k > ai, то перейти к шагу 5, если k = ai, алгоритм окончен удачно.

4. Установить u = i – 1 и перейти к шагу 2.

5. Установить l = i + 1 и перейти к шагу 2.

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







Дата добавления: 2015-09-04; просмотров: 783. Нарушение авторских прав; Мы поможем в написании вашей работы!




Функция спроса населения на данный товар Функция спроса населения на данный товар: Qd=7-Р. Функция предложения: Qs= -5+2Р,где...


Аальтернативная стоимость. Кривая производственных возможностей В экономике Буридании есть 100 ед. труда с производительностью 4 м ткани или 2 кг мяса...


Вычисление основной дактилоскопической формулы Вычислением основной дактоформулы обычно занимается следователь. Для этого все десять пальцев разбиваются на пять пар...


Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...

Растягивание костей и хрящей. Данные способы применимы в случае закрытых зон роста. Врачи-хирурги выяснили...

ФАКТОРЫ, ВЛИЯЮЩИЕ НА ИЗНОС ДЕТАЛЕЙ, И МЕТОДЫ СНИЖЕНИИ СКОРОСТИ ИЗНАШИВАНИЯ Кроме названных причин разрушений и износов, знание которых можно использовать в системе технического обслуживания и ремонта машин для повышения их долговечности, немаловажное значение имеют знания о причинах разрушения деталей в результате старения...

Различие эмпиризма и рационализма Родоначальником эмпиризма стал английский философ Ф. Бэкон. Основной тезис эмпиризма гласит: в разуме нет ничего такого...

Субъективные признаки контрабанды огнестрельного оружия или его основных частей   Переходя к рассмотрению субъективной стороны контрабанды, остановимся на теоретическом понятии субъективной стороны состава преступления...

ЛЕЧЕБНО-ПРОФИЛАКТИЧЕСКОЙ ПОМОЩИ НАСЕЛЕНИЮ В УСЛОВИЯХ ОМС 001. Основными путями развития поликлинической помощи взрослому населению в новых экономических условиях являются все...

МЕТОДИКА ИЗУЧЕНИЯ МОРФЕМНОГО СОСТАВА СЛОВА В НАЧАЛЬНЫХ КЛАССАХ В практике речевого общения широко известен следующий факт: как взрослые...

Studopedia.info - Студопедия - 2014-2025 год . (0.011 сек.) русская версия | украинская версия