第23650题 单选
给定C++二分查找代码在有序数组中查找31时while(left<=right)循环的执行次数是多少?

已知有序数组为 [1, 3, 6, 9, 17, 31, 39, 52, 61, 79],使用如下C++二分查找代码查找数值31:

int binary_search(vector<int>& nums, int target) {
    int left = 0;
    int right = nums.size() - 1;

    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (nums[mid] == target) {
            return mid;
        } else if (nums[mid] < target) {
            left = mid + 1;
        } else {
            right = mid - 1;
        }
    }

    return -1; // 如果找不到目标元素,返回-1
}
A

1

B

2

C

3

D

4

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