谁能告诉我这个二进制搜索代码在哪里出问题?无法将索引打印给用户

时间:2019-11-14 13:15:28

标签: python algorithm search

def binarySearch(list, selection):
  start = 0
  end = len(list) - 1

  while start <= end:
    middle = start + (end - start) // 2  
    middleValue = list[middle]
    if middleValue == selection:
      return middle
    elif selection < middleValue:
      end = middle - 1
    else:
      start = middle + 1

  return None

lista = [1, 5, 7, 10, 11, 19,]

print(lista)

selectiona = int(input('Enter a number to search for: '))
index = lista.index(selectiona)

binarySearch(lista, selectiona)


print(str(selectiona)) + "found at index " + str(index))

exit = input()

它无需打印索引即可工作,但这是必需的。如果有人可以建议我做错了什么,我将不胜感激。谢谢

2 个答案:

答案 0 :(得分:1)

print(str(selectiona)) + "found at index " + str(index))行中,您的括号是错误的,您在selectiona之后关闭了太多。尝试以下方法:

print(str(selectiona) + "found at index " + str(index))

此外,二进制搜索的结果不是您要打印的结果。您是否打算改用index = binarySearch(lista, selectiona)

答案 1 :(得分:1)

您正在index行使用python模块获取index = lista.index(selectiona),而没有使用binarySearch函数提供的输出。

def binarySearch(list, selection):
  start = 0
  end = len(list) - 1

  while start <= end:
    middle = start + (end - start) / 2  
    middleValue = list[middle]
    if middleValue == selection:
      return middle
    elif selection < middleValue:
      end = middle - 1
    else:
      start = middle + 1

  return None

lista = [1, 5, 7, 10, 11, 19,]

print(lista)

selectiona = int(input('Enter a number to search for: '))

index = binarySearch(lista, selectiona)

if index:
    print(str(selectiona) + " found at index " + str(index))
else:
    print(str(selectiona) + " is not there in the list")

exit = input()