温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Python实现二分查找

发布时间:2020-08-26 05:18:43 来源:网络 阅读:727 作者:小嘉欣 栏目:编程语言

搜索常见算法:顺序查找,二分法查找,哈希查找,下面是二分查找的实现方式

# coding:utf-8
# 二分查找的前提:只能对有序列进行查找
def binary_search(alist,item):
    """二分查找---递归实现"""
    n = len(alist)
    if n > 0:
        mid  = n//2
        if item == alist[mid] :
            return True
        elif item < alist[mid]:
            return binary_search(alist[:mid],item)
        else:
            return binary_search(alist[mid+1:], item)
    else :
        return False

def binary_search_2(alist,item):
    """二分查找---非递归版本"""
    n = len(alist)
    first = 0
    last = n-1
    while first <= last:
        mid = (first + last)//2
        if alist[mid] ==item:
            return True,mid
        elif item < alist[mid]:
            last = mid - 1
        else:
            first = mid + 1
    return False

if __name__ == "__main__":
    a = [1,5,6,10,11,13,18,37,99]
    print(a)
    sorted_list_11 = binary_search(a,1)
    print(sorted_list_11)
    sorted_list_12= binary_search(a, 88)
    print(sorted_list_12)
    sorted_list_21 = binary_search_2(a, 18)
    print(sorted_list_21)
    sorted_list_22 = binary_search_2(a, 88)
    print(sorted_list_22)

# [1, 5, 6, 10, 11, 13, 18, 37, 99]
# True
# False
# (True, 6)
# False
向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI