# Template A: Correct binary search
def search(arr, target):
 lo, hi = 0, len(arr)
 while lo < hi:
 mid = (lo + hi) // 2
 if arr[mid] < target:
 lo = mid + 1
 else:
 hi = mid
 return lo

# Template B: Off-by-one bug (< vs <=)
def search(arr, target):
 lo, hi = 0, len(arr)
 while lo <= hi: # BUG
 mid = (lo + hi) // 2
 if arr[mid] < target:
 lo = mid + 1
 else:
 hi = mid
 return lo
