为什么我的递归二进制搜索函数不返回任何内容?
Why is my recursive binary search function not returning anything?
(...数组值就别问了,他们是拉丁美洲的食品品牌,被一些朋友笑话了)。
def binSearch(arr, i, lower=0, upper=None):
if upper is None:
upper = len(arr)+1
idx = (lower+upper)//2
if arr[idx] == i:
print(idx, arr[idx],'\n')
#return idx
elif arr[idx] != i and upper-lower<2:
print("Not found \n")
#return False
elif arr[idx] < i:
print(idx, arr[idx])
binSearch(arr, i, idx, upper)
elif arr[idx] > i:
print(idx, arr[idx])
binSearch(arr, i, lower, idx)
myArray = ["Chabona", "F-Nandito VII", "La Bichy", "Manaos", "Martín y Enzo", "Pitusas", "Trompis", "Ugi's", "VAMOS MANAOS", "Villamanaos"]
binSearch(myArray, "Manaos")
binSearch(myArray, "Coca-Cola")
这个程序完全符合我的预期——输出如下:
5 Pitusas
2 La Bichy
3 Manaos
5 Pitusas
2 La Bichy
1 F-Nandito VII
Not found
但是,当我注释掉所有打印语句以使用 return idx
或 None
,然后将调用替换为 print(binSearch(myArray, "Manaos"))
和 print(binSearch(myArray, "Coca-Cola"))
:
None
None
它显然应该 return 3
和 False
但它 return 什么都没有。我做错了什么?
你没有returning:
return binSearch(arr, i, lower, idx)
您还需要return您的条件:
def binSearch(arr, i, lower=0, upper=None):
if upper is None:
upper = len(arr)+1
idx = (lower+upper)//2
if arr[idx] == i:
print(idx, arr[idx],'\n')
return idx # return 3/idx
elif arr[idx] != i and upper-lower<2:
print("Not found \n")
return False # return False
elif arr[idx] < i:
print(idx, arr[idx])
return binSearch(arr, i, idx, upper)
elif arr[idx] > i:
print(idx, arr[idx])
return binSearch(arr, i, lower, idx)
print(binSearch(myArray, "Manaos"))
print(binSearch(myArray, "Coca-Cola"))
5 Pitusas
2 La Bichy
3 Manaos
3
5 Pitusas
2 La Bichy
1 F-Nandito VII
Not found
False
(...数组值就别问了,他们是拉丁美洲的食品品牌,被一些朋友笑话了)。
def binSearch(arr, i, lower=0, upper=None):
if upper is None:
upper = len(arr)+1
idx = (lower+upper)//2
if arr[idx] == i:
print(idx, arr[idx],'\n')
#return idx
elif arr[idx] != i and upper-lower<2:
print("Not found \n")
#return False
elif arr[idx] < i:
print(idx, arr[idx])
binSearch(arr, i, idx, upper)
elif arr[idx] > i:
print(idx, arr[idx])
binSearch(arr, i, lower, idx)
myArray = ["Chabona", "F-Nandito VII", "La Bichy", "Manaos", "Martín y Enzo", "Pitusas", "Trompis", "Ugi's", "VAMOS MANAOS", "Villamanaos"]
binSearch(myArray, "Manaos")
binSearch(myArray, "Coca-Cola")
这个程序完全符合我的预期——输出如下:
5 Pitusas
2 La Bichy
3 Manaos
5 Pitusas
2 La Bichy
1 F-Nandito VII
Not found
但是,当我注释掉所有打印语句以使用 return idx
或 None
,然后将调用替换为 print(binSearch(myArray, "Manaos"))
和 print(binSearch(myArray, "Coca-Cola"))
:
None
None
它显然应该 return 3
和 False
但它 return 什么都没有。我做错了什么?
你没有returning:
return binSearch(arr, i, lower, idx)
您还需要return您的条件:
def binSearch(arr, i, lower=0, upper=None):
if upper is None:
upper = len(arr)+1
idx = (lower+upper)//2
if arr[idx] == i:
print(idx, arr[idx],'\n')
return idx # return 3/idx
elif arr[idx] != i and upper-lower<2:
print("Not found \n")
return False # return False
elif arr[idx] < i:
print(idx, arr[idx])
return binSearch(arr, i, idx, upper)
elif arr[idx] > i:
print(idx, arr[idx])
return binSearch(arr, i, lower, idx)
print(binSearch(myArray, "Manaos"))
print(binSearch(myArray, "Coca-Cola"))
5 Pitusas
2 La Bichy
3 Manaos
3
5 Pitusas
2 La Bichy
1 F-Nandito VII
Not found
False