#coding=utf-8
'''
二分查找又称折半查找
优点是比较次数少,查找速度快,平均性能好;
其缺点是要求待查表为有序表,且插入删除困难。
因此,折半查找方法适用于不经常变动而查找频繁的有序列表。
首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。
二分查找是有条件的,首先是有序,其次因为二分查找操作的是下标,所以要求是顺序表
2. 最优时间复杂度:O(1)
3. 最坏时间复杂度:O(logn)
'''
def binary_chop(a,n):#a是数组,n是要找的数
left=0
right=len(a)-1
while left<=right:
mid=(left+right)//2
if a[mid]==n:
return mid
if a[mid]<n:
letf=mid+1
else:
right=mid-1
return None
#第二种方法递归
left=0
right=len(a)-1
mid=(left+right)//2
if a[mid]==n:
return n
if mid<n:
self.binary_chop(a[mid+1:],n)
else:
self.binary_chop(a[:mid],n)
二分查找 (python)
最新推荐文章于 2023-01-23 21:06:14 发布