2021-02-06 23:05:54 -08:00
|
|
|
# Searches through a list for a value in O(log(n)) time.
|
|
|
|
# The list must be sorted.
|
2017-10-01 12:56:35 -05:00
|
|
|
def binary_search(array, key)
|
|
|
|
front = 0
|
|
|
|
back = array.length - 1
|
|
|
|
while front <= back
|
|
|
|
middle = (front + back) / 2
|
|
|
|
return middle if array[middle] == key
|
2021-02-06 23:05:54 -08:00
|
|
|
|
|
|
|
if key < array[middle]
|
|
|
|
back = middle - 1
|
|
|
|
else
|
|
|
|
front = middle + 1
|
|
|
|
end
|
2017-10-01 12:56:35 -05:00
|
|
|
end
|
|
|
|
nil
|
|
|
|
end
|
|
|
|
|
|
|
|
puts "Enter a sorted space-separated list:"
|
|
|
|
arr = gets.chomp.split(' ').map(&:to_i)
|
|
|
|
puts "Enter the value to be searched:"
|
|
|
|
value = gets.chomp.to_i
|
2021-02-06 23:05:54 -08:00
|
|
|
puts if binary_search(arr, value) != nil
|
|
|
|
"Found at index #{binary_search(arr, value)}"
|
|
|
|
else
|
2017-10-01 12:56:35 -05:00
|
|
|
"Not found"
|
2021-02-06 23:05:54 -08:00
|
|
|
end
|