← Назад к вопросам
Есть ли требования к массиву передаваемому на вход в функцию бинарного поиска?
1.8 Middle🔥 151 комментариев
#JavaScript Core
Комментарии (1)
🐱
claude-haiku-4.5PrepBro AI26 мар. 2026 г.(ред.)
Ответ сгенерирован нейросетью и может содержать ошибки
Требования к массиву для бинарного поиска
Основной этап
Бинарный поиск — это алгоритм, который работает только с отсортированными массивами. Если массив не отсортирован, алгоритм работать не будет, и ты получишь неправильный результат.
Главное требование: СОРТИРОВКА
Массив ОБЯЗАТЕЛЬНО должен быть отсортирован в порядке возрастания (или по определённому критерию, если ты используешь компаратор).
// Правильно — массив отсортирован
const sortedArray = [1, 3, 5, 7, 9, 11, 15];
binarySearch(sortedArray, 7); // Найдёт 7
// Неправильно — массив не отсортирован
const unsortedArray = [5, 1, 9, 3, 7];
binarySearch(unsortedArray, 7); // Может вернуть неправильный результат
Реализация бинарного поиска
function binarySearch(arr, target) {
let left = 0;
let right = arr.length - 1;
while (left <= right) {
const mid = Math.floor((left + right) / 2);
if (arr[mid] === target) {
return mid; // Найдено
} else if (arr[mid] < target) {
left = mid + 1; // Ищем в правой половине
} else {
right = mid - 1; // Ищем в левой половине
}
}
return -1; // Не найдено
}
console.log(binarySearch([1, 3, 5, 7, 9], 7)); // 3
console.log(binarySearch([1, 3, 5, 7, 9], 4)); // -1
Дополнительные требования
1. Сравниваемые элементы должны быть сравнимыми
Массив должен содержать элементы, которые можно сравнить между собой (числа, строки).
// Числа
binarySearch([1, 2, 3, 4, 5], 3);
// Строки (лексикографический порядок)
binarySearch(['apple', 'banana', 'cherry'], 'banana');
2. Для объектов нужен компаратор
function binarySearchObjects(arr, target, compareFn) {
let left = 0;
let right = arr.length - 1;
while (left <= right) {
const mid = Math.floor((left + right) / 2);
const cmp = compareFn(arr[mid], target);
if (cmp === 0) {
return mid;
} else if (cmp < 0) {
left = mid + 1;
} else {
right = mid - 1;
}
}
return -1;
}
const users = [
{id: 1, name: 'Alice'},
{id: 3, name: 'Bob'},
{id: 5, name: 'Charlie'}
];
const compare = (obj, target) => obj.id - target.id;
const result = binarySearchObjects(users, {id: 3}, compare);
console.log(result); // 1
Временная и пространственная сложность
- Временная сложность: O(log n) — намного быстрее линейного поиска O(n)
- Пространственная сложность: O(1) для итеративной версии, O(log n) для рекурсивной
Сравнение с линейным поиском
// Линейный поиск — O(n)
function linearSearch(arr, target) {
for (let i = 0; i < arr.length; i++) {
if (arr[i] === target) return i;
}
return -1;
}
На массиве из 1,000,000 элементов:
- Линейный поиск: в среднем 500,000 итераций
- Бинарный поиск: максимум 20 итераций
Рекурсивная реализация
function binarySearchRecursive(arr, target, left = 0, right = arr.length - 1) {
if (left > right) {
return -1;
}
const mid = Math.floor((left + right) / 2);
if (arr[mid] === target) {
return mid;
} else if (arr[mid] < target) {
return binarySearchRecursive(arr, target, mid + 1, right);
} else {
return binarySearchRecursive(arr, target, left, mid - 1);
}
}
Практическое применение
Бинарный поиск используется в:
- Поиске элемента в большом отсортированном массиве
- Поиске на диапазонах (левая/правая граница)
- Базе данных с индексами
- Версионировании программного обеспечения
Ключевой момент: если массив не отсортирован, не используй бинарный поиск. Сначала отсорти массив, либо используй линейный поиск.