class BinarySearch:
def getPos(self, A, n, val):
val_pos = -1
left = 0
right = n-1
now_pos = (left + right)//2
while 1:
if A[now_pos] < val: # 当前值 < val,
if val == A[now_pos+1]: # 右边第一个 = val
val_pos = now_pos + 1 # 更新val_pos
break # 跳出
left = now_pos
now_pos = (left + right)//2
else: # A[now_pos] >= val # 当前值 = val,仍要「向左查找」,确保找到「第一次出现的位置」
right = now_pos
now_pos = (left + right)//2
if left==right-1: # 范围缩小到两个数
if val==A[left]:
val_pos = left # 优先输出左边
elif val==A[right]:
val_pos = right
break # 即使左右都不符合也要break
return(val_pos)
def binary_search(li,v,l,r):
"""
li: Input list
v: target value
l: left index
r: right index
"""
if l>r: # 遍历列表直到left>right也没找到v
return -1
else:
mid = (l+r)//2 # 二分取左边
if li[mid] == v: # 中位数刚好就是 v,返回当前中位数索引
return mid
elif li[mid] < v: # v在中位数右边,将左边界l替换为 mid+1 向下递归
return binary_search(li,v,mid+1,r)
else: # v在中位数左边,将右边界r替换为 mid-1 向下递归
return binary_search(li,v,l,mid-1)
a = [-3, -2, 0, 1, 5, 7, 10 ,99, 111]
v = 99
init_l = 0
init_r = len(a)-1
binary_search(a,v,init_l,init_r)