二分查找 Python

二分法可以求有序数组中是否存在该值

标准答案

def binary_search(nums,value):

    low = 0
    pre = len(nums) - 1

    while (low <= pre):
        middle = int((low + pre)/2)
        if (nums[middle] > value):
            pre = middle - 1
        elif (nums[middle] < value):
            low = middle + 1
        else:
            return middle

    return -1

1. 找到头尾(用下标作为头尾)

2. 中间值找法(头尾相加/2得到的整数,肯定会小于尾标不越界)

3. 头尾标更换(大于小于等于判断,注意这里middle值要+-1跳过)

递归 

二分法常见的写法还有递归形式,这个面试时面试官主要想考察面试者能否理解递归时会考察

递归的优势在于理解和背算法的时候简单,但是面试的时候最好不要上来就是一个递归,会被打低分的。

其实这个算法,递归反而好像更复杂了。

def binary_search(nums,value,low,pre):
    if low > pre or len(nums) == 0:
        return -1
    else:
        middle = int((low + pre)/2)
        if nums[middle] == value:
            return middle
        else:
            if nums[middle] < value:
                return binary_search(nums,value,middle+1,pre)
            else:
                return binary_search(nums,value,low,middle-1)

递归的话记住关注return相关,其他的注意点或者判断以及对middle值的处理实际上和使用循环的相同,一般二叉树,斐波那契数列用递归还有理由说比较好理解,二分法实在是没有上来就用递归的

二分法是面试时考察代码中的一个最基本的算法,一般技术面没有那么多时间去思考这种通用型算法,面试官也一般上来不会让你来坎巴拉造火箭,二分法算是最基础的一个算法考察,一般不会直接考,更多的是融入到具体的场景题目中去,不管他怎么考察,都建议直接背过才能面试时不慌。

也别眼高手低看不起这种“低级算法”,见过太多面试时话都说不明白的,别说二分法了,一个小循环都能写错的,直接拉低了面试分。所以这种算法不仅要了如指掌,更要熟记于心。

如果面试题中是在一个排序的数组中找到一个值,就要考虑使用二分法来解决。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值