我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

Python实现二分查找

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

员工经过长期磨合与沉淀,具备了协作精神,得以通过团队的力量开发出优质的产品。创新互联坚持“专注、创新、易用”的产品理念,因为“专注所以专业、创新互联网站所以易用所以简单”。公司专注于为企业提供做网站、成都网站制作、微信公众号开发、电商网站开发,小程序制作,软件按需求定制设计等一站式互联网企业服务。

# 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

分享文章:Python实现二分查找
URL标题:http://shouzuofang.com/article/gosdsg.html

其他资讯