二分问题的思考步骤:
- 写一个check函数
- 判断check(mid)函数为true时mid落到了左半边还是右半边
- 更新区间
比如图中如果找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;
}