二分查找

一、迭代

def binary_search(key, ls):
    left = 0
    right = len(ls) -1

    while left <= right:
        mid = (left + right) // 2

        if key == ls[mid]:
            return mid
        elif key < ls[mid]:
            right = mid - 1
        elif key > ls[mid]:
            left = mid + 1
    return -1

二、递归

def binary_search(ls, low, high, key):
    if low > high:
        return -1
    else:
        mid = (low+high)//2
        if key == ls[mid]:
            return mid
        elif key > ls[mid]:
            return binary_search(ls, mid+1, high, key)
        else:
            return binary_search(ls, low, mid-1, key)
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容