Ниже приведен псевдокод, полученный из учебника TopCoder о бинарном поиске
binary_search(A, target):
lo = 1, hi = size(A)
while lo <= hi:
mid = lo + (hi-lo)/2
if A[mid] == target:
return mid
else if A[mid] < target:
lo = mid+1
else:
hi = mid-1
// target was not found
Почему мы вычисляем среднее значение как mid = lo + (hi-lo)/2? Что случилось с (hi + lo)/2
У меня есть небольшая идея, что это может быть предотвращение переполнения, но я не уверен, возможно, кто-то может объяснить это мне, и если есть другие причины этого.