Back to questions
VK
Junior — Middle
66
Какие методы можно использовать для быстрого поиска элемента в отсортированном массиве, минимизируя временные затраты?
Companies where asked
Answer from AI
sobes.tech AI
Для быстрого поиска элемента в отсортированном массиве обычно используют алгоритм бинарного поиска (binary search). Он минимизирует временные затраты, так как работает за время O(log n), где n — размер массива.
Идея бинарного поиска:
- Сравнить искомый элемент с элементом в середине массива.
- Если они равны — элемент найден.
- Если искомый элемент меньше — повторить поиск в левой половине.
- Если больше — в правой половине.
В iOS (Swift) можно использовать метод binarySearch или реализовать его самостоятельно.
Пример на Swift:
func binarySearch<T: Comparable>(_ array: [T], target: T) -> Int? {
var low = 0
var high = array.count - 1
while low <= high {
let mid = (low + high) / 2
if array[mid] == target {
return mid
} else if array[mid] < target {
low = mid + 1
} else {
high = mid - 1
}
}
return nil
}
let sortedArray = [1, 3, 5, 7, 9]
if let index = binarySearch(sortedArray, target: 5) {
print("Элемент найден на позиции \(index)")
} else {
print("Элемент не найден")
}