你真的会二分搜索吗

二分问题的思考步骤:

  1. 写一个check函数
  2. 判断check(mid)函数为true时mid落到了左半边还是右半边
  3. 更新区间

比如图中如果找10的左区间,那么mid应该落在右半边,不断向左更新,直到找到左边界

bool check_r(int mid, int x)
{
    if(a[mid]<=x) return true;
    return false;
}

对应的二分模板为:

int l = 0, r = n-1;
while(l<r)
{
    int mid = l+r>>1;
    if(check_r(mid)) r = mid;
    else l = mid+1;
}

如果找10的右区间,那么mid应该落在左半边,不断向右更新,直到找到右边界

bool check_l(int mid, int x)
{
    if(a[mid]>=x) return true;
    return false;
}

对应的二分模板为:

int l = 0, r =n-1;
while(l<r)
{
    int mid = l+r+1>>1;  /*这里加1是因为如果 l = r-1, 更新之后mid = l, 如果check()==true, 那么区间仍然为[l,r] 会发生死循环*/                        
    
if(check_l(mid, x)) l = mid;
    else r = mid-1;
 } 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值