2020-12-20 16:08:48 -08:00
|
|
|
# A pure Ruby implementation of a recursive linear search algorithm
|
2020-12-20 16:06:24 -08:00
|
|
|
|
|
|
|
def rec_linear_search(sequence, low, high, target)
|
2020-12-20 16:08:48 -08:00
|
|
|
raise Exception('Invalid upper or lower bound!') unless high < sequence.length && low < sequence.length
|
|
|
|
|
|
|
|
return -1 if high < low
|
|
|
|
|
|
|
|
return low if sequence[low] == target
|
|
|
|
|
|
|
|
return high if sequence[high] == target
|
|
|
|
|
|
|
|
rec_linear_search(sequence, low + 1, high - 1, target)
|
2020-12-20 16:06:24 -08:00
|
|
|
end
|
|
|
|
|
|
|
|
puts(rec_linear_search([0, 30, 500, 100, 700], 0, 4, 0))
|
|
|
|
# => 0
|
2020-12-20 16:08:48 -08:00
|
|
|
|
2020-12-20 16:06:24 -08:00
|
|
|
puts(rec_linear_search([0, 30, 500, 100, 700], 0, 4, 700))
|
|
|
|
# => 4
|
2020-12-20 16:08:48 -08:00
|
|
|
|
2020-12-20 16:06:24 -08:00
|
|
|
puts(rec_linear_search([0, 30, 500, 100, 700], 0, 4, 30))
|
|
|
|
# => 1
|
2020-12-20 16:08:48 -08:00
|
|
|
|
2020-12-20 16:06:24 -08:00
|
|
|
puts(rec_linear_search([0, 30, 500, 100, 700], 0, 4, -6))
|
|
|
|
# => -1
|