钢铁键盘侠 2023-06-01 08:59 采纳率: 0%
浏览 9

关于使用python的二分查找

二分查找

如果实例的查找在范围内可以精准找到,但是大于,我的程序就没有结果,不停止运行。比如输入88,程序就一直运行,不停止

def binary_for(li,val):
    left = 0
    right = len(li) - 1
    while left <= left:
        mid = (left + right)//2
        if li[mid] == val:
            return mid
        elif li[mid] < val:
            left = mid + 1
        else:
            right = mid - 1

    else:
        return -1

list1 = list(range(1,9))
b=binary_for(list1,88)
print(b)

img

  • 写回答

3条回答 默认 最新

  • 小小小小人水豚 2023-06-01 09:10
    关注

    第4行应该是while left <= right:这么写吧,自己跟自己比,小于等于永远成立就死循环了。

    有帮助的话,请点采纳该答案~

    评论

报告相同问题?

问题事件

  • 创建了问题 6月1日

悬赏问题

  • ¥15 obsidian的中文层级自动编号
  • ¥15 同一个网口一个电脑连接有网,另一个电脑连接没网
  • ¥15 神经网络模型一直不能上GPU
  • ¥15 pyqt怎么把滑块和输入框相互绑定,求解决!
  • ¥20 wpf datagrid单元闪烁效果失灵
  • ¥15 券商软件上市公司信息获取问题
  • ¥100 ensp启动设备蓝屏,代码clock_watchdog_timeout
  • ¥15 Android studio AVD启动不了
  • ¥15 陆空双模式无人机怎么做
  • ¥15 想咨询点问题,与算法转换,负荷预测,数字孪生有关