Курс Python → Бинарный поиск
Алгоритм бинарного поиска — это эффективный метод поиска элемента в отсортированном массиве. Он основан на принципе «разделяй и властвуй», который позволяет быстро сузить область поиска. Для начала работы алгоритм принимает отсортированный список, в котором будет осуществляться поиск. Затем алгоритм постоянно сравнивает значение поиска с серединой массива.
В зависимости от результата сравнения, алгоритм либо сужает область поиска до левой или правой половины массива, либо находит искомый элемент. Этот процесс продолжается до тех пор, пока не будет найден искомый элемент или область поиска сузится до пустого массива. Благодаря этому непрерывному делению массива на две части, алгоритм обеспечивает логарифмическую временную сложность.
def binary_search(arr, target):
low = 0
high = len(arr) - 1
while low <= high:
mid = (low + high) // 2
if arr[mid] == target:
return mid
elif arr[mid] < target:
low = mid + 1
else:
high = mid - 1
return -1
Пример кода выше представляет функцию бинарного поиска на Python. Она принимает отсортированный массив и значение, которое необходимо найти в этом массиве. Функция последовательно сравнивает значение поиска с серединой массива и сужает область поиска до тех пор, пока не будет найден искомый элемент или область поиска не станет пустой. Если элемент найден, функция возвращает его индекс в массиве, в противном случае возвращается -1.
Другие уроки курса "Python"
- Форматирование строк в Python
- Исключение NotImplementedError
- Отслеживание выполнения программы с библиотекой tqdm
- Поиск частого элемента
- Обработка аргументов Python
- Комментарии в Python
- Работа со строками
- Срез списка в Python
- Работа с модулем glob в Python
- Лямбда-функции для min/max
- Работа с CSV файлами
- Проблема с изменяемыми аргументами
- Перевод эмодзи и эмотиконов.
- Работа с Enum в Python3.
- Операторы += в Python
- Работа с collections.Counter
- Библиотека wikipedia для Python
- Разделение строки с помощью split()
- Класс UserDict: дополнительная функциональность
- Форматирование строк в Python.
- Списковый компрехеншен.
- Измерение времени выполнения с помощью time
- Метод __call__ в Python
- Любовь к Python
- Списковое включение в Python
- Получение ID текущего процесса
- Генераторы в Python
- Инициализация переменных
- Разделение функций на этапы
- Многострочные строки в Python
- Аргумент по умолчанию
- Создание множества в Python
- Функция all() в Python
- List Comprehension Tutorial
- Перезапуск ячейки в Jupyter Notebook с dostoevsky
- Генератор списка в Python
- Обновление ключей в Python
- Генераторы в Python
- Оптимизация методов в Python 3.7
- Работа с getopt
- Работа с парами ключ-значение
- Фильтрация списка от «ложных» значений
- Отношения подклассов в Python
- Изменение IP-адреса в Python
- Особенности запятых в Python
- Хранение данных















