Commit 7e6535a8 by BellCodeEditor

save project

parent 1bdba280
Showing with 25 additions and 16 deletions
# 使用二分查找法,找出9和20在列表里面的索引 import random
bingo_num = 20
num_list = [1, 3, 5, 8, 11, 15, 17, 18, 20, 21]
low = 0
high = len (num_list)-1
while low <= high:
mid = (low + high)//2 alist = []
guess_num = num_list[mid] for i in range(1,100):
if guess_num == bingo_num: alist.append(i)
print('找到了,数字是:',mid) num = random.choice(alist)
break
elif bingo_num > guess_num: def binary_search(alist,num):
low = mid+1 low = 0
else: high = len (alist)-1
high = mid-1
\ No newline at end of file while low <= high:
mid = (low + high)//2
guess_num = alist[mid]
if guess_num == num:
return mid
elif guess_num < num:
low = mid+1
else:
high = mid-1
return None
result = binary_search(alist,num)
print(num)
print(result)
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or sign in to comment