python(day17)二分查找

2018-11-09 02:39:47来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

l = [1,3,5,7,9,11,13,15,17,19,21,23,25,27,29,31]
def find(l ,aim ,start = 0,end = None):
    end = len(l) if end is None else end    #end的问题解决
    mid_index = ( end - start )//2 + start  #中间数下标问题的解决
    if start <=end:                         #找不到问题的解决
        if l[mid_index]<aim:
            return find(l ,aim ,start = mid_index+1,end = end ) 
        elif l[mid_index]>aim:
            return find(l,aim, start = start,end = mid_index - 1)
        else:
            return mid_index
    else:
        return '没有找到'
#l = [1,3,5,7,9,11,13,15,17,19,21,23,25,27,29,31]
ret = find(l,27)
print(ret)
#注意,是len(l),还有end = end ,start = start,+1-1要注意

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:zabbix user parameters和Loadable modules的使用方法介绍

下一篇:理解Python闭包概念