Sobes.tech
Back to questions
Junior — Middle
81

Как определяется временная сложность алгоритма двоичного поиска?

Companies where asked
HyperRus

Answer from AI

sobes.tech AI

Временная сложность алгоритма двоичного поиска определяется как O(log n), где n — количество элементов в отсортированном массиве. Это связано с тем, что на каждом шаге алгоритм делит область поиска пополам, уменьшая количество рассматриваемых элементов в два раза, пока не найдет искомый элемент или не убедится в его отсутствии.

Пример на Go:

func binarySearch(arr []int, target int) int {
    left, right := 0, len(arr)-1
    for left <= right {
        mid := left + (right-left)/2
        if arr[mid] == target {
            return mid
        } else if arr[mid] < target {
            left = mid + 1
        } else {
            right = mid - 1
        }
    }
    return -1 // элемент не найден
}