今天爱分享给大家带来python实现二分查找【面试题详解】【附代码】,希望能够帮助到大家。
def binary_chop(alist, data):
"""
非递归解决二分查找
"""
n = len(alist)
first = 0
last = n - 1
while first <= last:
mid = (last+first)//2
if alist[mid] > data:
last = mid - 1
elif alist[mid] < data:
first = mid + 1
else:
return True
return False
def binary_chop2(alist, data):
"""
递归解决二分查找
"""
n = len(alist)
if n < 1:
return False
mid = n // 2
if alist[mid] > data:
return binary_chop2(alist[0:mid], data)
elif alist[mid] < data:
return binary_chop2(alist[mid+1:], data)
else:
return True
if __name__ == "__main__":
lis = [2,4, 5, 12, 14, 23]
if binary_chop(lis, 12):
print('ok')
else:
print('false')
原文链接:http://blog.itblood.com/4573.html,转载请注明出处。

![任性旅行者之家v0.19 AI版[PC+安卓/10.7G/更新]Home for Wayward Travellers [v0.19 Public] [亚洲SLG/汉化/沙盒]](/wp-content/uploads/replace/2025/09/01/20725f1b357af6ad6128df20c5072bdc.webp)