Sobes.tech
Back to questions
Junior — Middle
66

Какие методы можно использовать для быстрого поиска элемента в отсортированном массиве, минимизируя временные затраты?

Companies where asked
VKVK

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("Элемент не найден")
}