资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

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实现二分查找
分享地址:http://www.cdkjz.cn/article/gosdsg.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220