其他分享
首页 > 其他分享> > 4.1左侧边界原思路

4.1左侧边界原思路

作者:互联网

左侧边界原思路

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

1.为什么没有返回 -1 的操作?

image-20220509231309129

理解左侧边界有什么特殊含义

算法返回索引1,解读为【nums中小于2的元素有1个】

再比如,对于nums = [2,3,5,7],target = 1,算法返回0,含义是:nums中小于1的元素有0个

target=8,算法返回4,含义是:nums中小于8的元素有4个

对于target 不存在 nums 中的情况,函数的返回值还可以有多种理解方式

函数的返回值,即left变量的值,取值范围是 闭区间[0,num.length]

2.为什么 left = mid + 1, right = mid?

搜索区间 左闭右开 [left,right),nums[mid]被检测之后,下一步应该去掉mid 分割成两个区间

即[left,mid) , [mid+1,right)

3.为什么能够搜索左侧边界?

关键在于,找到target时,不要立即返回。而是缩小搜索区间的上界 right,在 区间[left,mid)中继续搜索,即不断向左收缩,达到锁定左侧边界的目的

image-20220509231324153

while的退出条件 left == right + 1,所以当target比nums中所有元素都大时,会存在以上情况使索引越界

同理,右侧边界

image-20220509231424928

标签:right,4.1,边界,nums,int,mid,左侧,target,left
来源: https://www.cnblogs.com/autumnmoonming/p/16282432.html