二分搜索模板

1. 寻找一个数

int binary_search(int[] nums, int target) {
    
    
    int left = 0, right = nums.length - 1; 
    while(left <= right) {
    
    
        int mid = left + (right - left) / 2;
        if (nums[mid] < target) {
    
    
            left = mid + 1;
        } else if (nums[mid] > target) {
    
    
            right = mid - 1; 
        } else if(nums[mid] == target) {
    
    
            // 直接返回
            return mid;
        }
    }
    // 直接返回
    return -1;
}

搜索区间是两端闭区间。

2. 寻找左侧边界

int left_bound(int[] nums, int target) {
    
    
    int left = 0, right = nums.length - 1;
    while (left <= right) {
    
    
        int mid = left + (right - left) / 2;
        if (nums[mid] < target) {
    
    
            left = mid + 1;
        } else if (nums[mid] > target) {
    
    
            right = mid - 1;
        } else if (nums[mid] == target) {
    
    
            // 别返回,锁定左侧边界
            right = mid - 1;
        }
    }
    // 最后要检查 left 越界的情况
    if (left >= nums.length || nums[left] != target)
        return -1;
    return left;
}

为了方便记忆,搜索区间也是两端闭区间。

3.寻找右侧边界

int right_bound(int[] nums, int target) {
    
    
    int left = 0, right = nums.length - 1;
    while (left <= right) {
    
    
        int mid = left + (right - left) / 2;
        if (nums[mid] < target) {
    
    
            left = mid + 1;
        } else if (nums[mid] > target) {
    
    
            right = mid - 1;
        } else if (nums[mid] == target) {
    
    
            // 别返回,锁定右侧边界
            left = mid + 1;
        }
    }
    // 最后要检查 right 越界的情况
    if (right < 0 || nums[right] != target)
        return -1;
    return right;
}

为了方便记忆,搜索区间也是两端闭区间。

总结

二分搜索的关键就在于搜索区间,明确了搜索区间的定义(到底是两端闭区间还是左闭右开区间),那么直接根据逻辑写代码即可。需要注意的细节是:while退出条件、while结束后的检查操作。

猜你喜欢

转载自blog.csdn.net/weixin_38708854/article/details/108726974
今日推荐