请看这段代码:
def chop(array, search):
lo = 0
high = len(array) - 1
while lo <= high:
mid = (high + lo) /2
if array[mid] == search:
return 'true'
elif search > array[mid]:
low = mid + 1
else:
high = mid - 1
return 'false'
if __name__ == '__main__':
a = [1,2,3,4,5,6,7,8,9,10]
print chop(a, 3)
我写了这个小脚本,它应该在数组中搜索数字 - 常规二进制搜索。所以我运行脚本,例如当我放入chop(a, 1)
时我得到了真的,当我放入chop(a, 2)
时我得到了真实,但当我放chop(a, 3)
时我得不到回答,只是Python Shell中的空行。
有没有人知道发生了什么?
答案 0 :(得分:12)
我猜这是你的错误:
low = mid + 1
您的while循环使用变量lo
,并且您在while循环中定义了一个名为low
的新变量。从本质上讲,您永远不会更新lo
变量。
将该行更改为:
lo = mid + 1
并且您的算法应该有效。