我的任务是使用 Ruby 制作更高效的二进制搜索代码。我遵循了这个链接的逻辑: http ://www.cprogramming.com/discussionarticles/sorting_and_searching.html
我的代码如下:
def bsearch(a, k)
lower = 0
upper = a.length-1
while a[upper].to_f> k.to_f and a[lower].to_f< k.to_f
low_diff = k.to_f -a[lower].to_f
range_diff = a[upper].to_f-a[lower].to_f
count_diff = upper-lower
range = low_diff/range_diff * count_diff + lower
if k==a[lower]
return lower
if k.to_f > a[range].to_f
lower = range+1
else if k.to_f < a[range].to_f
upper =range
else
lower = range
end
end
end
我仔细检查,但我不知道为什么我一直遇到以下错误:
unexpected $end , expecting kEND