在计算机科学中,二分查找算法(英语:binary search algorithm),也称折半搜索算法(英语:half-interval search algorithm)[1]、对数搜索算法(英语:logarithmic search algorithm)[2],是一种在有序数组中查找某一特定元素的搜索算法。搜索过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜索过程结束;如果某一特定元素大于或者小于中间元素,则在数组大于或小于中间元素的那一半中查找,而且跟开始一样从中间元素开始比较。如果在某一步骤数组为空,则代表找不到。这种搜索算法每一次比较都使搜索范围缩小一半。
# -*- coding:utf-8 -*-
def binary_search(find_list, item):
first = 0
last = len(find_list) - 1
found = False
while first <= last and not found:
mid = (first + last) // 2
if find_list[mid] == item:
return True
else:
if item < find_list[mid]:
last = mid - 1
else:
first = mid + 1
return found
test_list = [0, 3, 11, 23, 34, 48, 54, 75, 97]
print(binary_search(test_list, 23))