[模板]二分答案

1.使用场景

二分答案通常使用在求解符合条件的最小值或者最大值上面,当咱们遇到这两个问题的时候,通常均可以使用二分答案来解决问题。函数

2.什么是二分答案

二分答案就是经过对全部可能的答案区间进行折半查找,不断缩减范围,最终肯定答案的方法。code

3.求最小值

//求最小值
int binary(int left, int right) {
    int mid;
    while(left < right) {
        mid = (right + left) / 2;
        if (check(mid)) right = mid;
        else left = mid + 1;
    }
    return left;
}

咱们能够知道,要求最小值,那么所知足条件的值赋值给右边界,不知足的值加一赋值给左边界,当left == right或者left > right时,则说明已经查询到符合的最小值。class

4.求最大值

//求最大值
int binary(int left, int right) {
    int mid;
    while(left < right) {
        mid = (right + left + 1) / 2;
        if (check(mid)) left = mid;
        else right = mid - 1;
    }
    return left;
}

一样,要求最大值,那么就须要舍弃符合条件的较小的值,即将左边界赋值符合条件的点,右边界赋值不符合条件的值减一。不断查询下去,则最后剩下符合条件最大值。其中mid = (right + left + 1) / 2是为了防止无限循环,由于当left = right + 1时恰好符合条件,left = (right + left) / 2,就会无限循环。循环

5. check函数构思

咱们既然选择了使用二分法来求解,那么咱们在check的时候,应该是在咱们已知答案的状况下去确认答案,即不是从通常思考方向设想,而是验证。check函数每每是基于假定知道答案,来验证是否正确。方法

相关文章
相关标签/搜索