二分不迷茫

最简单的二分

最近在很多题里要自己实现二分,二分的边界条件,与判断语句里等号的取舍,L和R与mid之间的±1的取舍都很多,每个地方差一点就是一个不同的二分,在太多的复杂情况下,其实只要抓住stl二分的源码也就是*lower_bound() upper_boudn()*就能做到不出错。
以下是对两个函数的实现

int lower_bound(vector<int>&nums,int targrt){

		int l=0,r=nums.size()-1;
		while(l<r)
		{
			int mid=l+(r-l)/2;
			int num=nums[mid];
			if(nums[mid]>=target)	r=mid;
			else l=mid+1;
		}
		return l||r;
}
int upper_bound(vector<int>&nums,int targrt){

		int l=0,r=nums.size()-1;
		while(l<r)
		{
			int mid=l+(r-l)/2;
			int num=nums[mid];
			if(nums[mid]>target)	r=mid;
			else l=mid+1;
		}
		return l||r;
}

最后返回L或者R都是可以的,因为最后L=R了,成一个点了,我们可以看到lowerbound和upperbound的实现非常相似,仅仅是一个大于号和大于等于号的区别,这是因为这两个函数其实都是求在有相同元素的数组里,求一个下界的函数,lower是求>=target的下界,upper是求>target的下界。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值