ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

4.1左侧边界原思路

2022-05-17 21:35:24  阅读:152  来源: 互联网

标签:right 4.1 边界 nums int mid 左侧 target left


左侧边界原思路

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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有