1
0
Fork 0
mirror of https://github.com/TheAlgorithms/Ruby synced 2025-01-25 19:58:41 +01:00
TheAlgorithms-Ruby/Searches/binary_search.rb

28 lines
602 B
Ruby
Raw Normal View History

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.
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
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
"Not found"
2021-02-06 23:05:54 -08:00
end