二进制搜索python奇怪的行为

时间:2012-03-29 02:32:42

标签: python binary-search

请看这段代码:

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中的空行。

有没有人知道发生了什么?

1 个答案:

答案 0 :(得分:12)

我猜这是你的错误:

low = mid + 1

您的while循环使用变量lo,并且您在while循环中定义了一个名为low的新变量。从本质上讲,您永远不会更新lo变量。

将该行更改为:

lo = mid + 1

并且您的算法应该有效。