您的位置:首页 > 编程语言 > Ruby

ruby普通二分查找和递归二分查找

2017-12-16 14:42 330 查看
#普通二分查找
def binSearch(arr,value)
left=0
right=arr.length-1
while left<=right
center=(left+right)/2
if arr[center]== value
return center
elsif arr[center]<value
left=center+1
else
right=center-1
end
end
return -1
end

#递归二分查找
def binSearchRecursive(arr,value)
left=0
right=arr.length-1
_binSearchRecursive(arr,value,left,right)
end

#inner fun
def _binSearchRecursive(arr,value,left,right)
center=(left+right)/2

if right-left<0
return -1
elsif arr[center]==value
return center
elsif arr[center]>value
return _binSearchRecursive(arr,value,left,center-1)
else arr[center]<value
return _binSearchRecursive(arr,value,center+1,right)
end
end

arr=[1,2,3,4,5,6,7]
puts binSearch(arr,5)
puts binSearchRecursive(arr,5)


欢迎关注我的github https://github.com/luckyCatMiao
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  ruby 二分查找 递归