第20665题 单选
下列关于给定C++实现lower_bound函数代码的说法,正确的是

下面C++代码尝试在有序数组中查找第一个大于等于 x 的元素位置。如果没有大于等于 x 的元素,返回 arr.size() 。以下说法正确的是( )。

int lower_bound(vector<int>& arr, int x) {
    int l = 0, r = arr.size();
    while(l < r) {
        int mid = l + (r - l) / 2;
        if(arr[mid] >= x) r = mid;
        else l = mid + 1;
    }
    return l;
}
A

上述代码逻辑正确

B

上述代码逻辑错误,while循环条件应该用l <= r

C

上述代码逻辑错误,mid计算错误

D

上述代码逻辑错误,边界条件不对

提交0次 正确率0.00%
答案解析