补全Python二分查找代码,在非降密码本序列中查找最接近电子钥匙的整数(多解取最小)
类型:程序题

密码问题

根据密码本和电子钥匙,破解笔记本电脑的密码。 密码本是一个非降的整数序列,电子钥匙是一个整数,得到密码的方法是在密码本中找到最接近电子钥匙的整数(如果多个符合条件,输出最小的一个)。

示例

密码本为下面的列表: a = [1,22,43,45,45,55,60,70,89] 电子钥匙为整数44,满足条件的整数为43和45,最终的密码为43。

请补全下面的代码:

a = [1,22,43,45,45,55,60,70,89] # 密码本
k = int(input())   # k为电子钥匙
l = 0
r = 8
while l + 1 != r:
    mid = int(   ①   )
    if a[mid] < k:
           ②
    else:
        r = mid
    if a[r] == k:
           ③
if k - a[l] <=     ④    :
    print(a[l])
else:
    print(⑤)
代码编辑器 加载中...
测试用例(F10) 运行测试(F11) 提交答案(F12)
测试用例输入
{{resultStatus.text}}