首页 > 解决方案 > 使用递归返回“无”的二进制搜索函数

问题描述

我已经为二进制搜索编写了代码。它打印中间值,但在退出函数时不返回相同的值。

def binarysearch(array,low,high,key):
  mid=(low+high)//2
  if array[mid]==key:
    print ('arrar[mid]: ',array[mid],'mid= ', mid)
     return mid
  elif key> array[mid]:
    binarysearch(array, low+1, high,key)
  elif key<array[mid]:
    binarysearch(array,low,mid-1,key)
  else:
    return -1


data=[1,2,3,4,5]
result=binarysearch(data,0,5,5)
print('result=',result)

输出:

 arrar[mid]: 5 mid =4
 result=None

标签: binary-search

解决方案


elif key> array[mid]:
binarysearch(array, low+1, high,key)

应该

elif key> array[mid]:
binarysearch(array, mid, high,key)

推荐阅读