C++二分答案 —— 入门篇

前言

在上一篇博客内我大概讲了一下二分
C++二分算法 – 基础篇

现在我要讲一下二分答案的基础

例子

我要找一个特定(有范围、或者其他要求的数)的数,这时候,我们可能第一个想到的思路是暴力枚举,但是时间会超时
例如这道题:P1024 [NOIP2001 提高组] 一元三次方程求解
这个题目看似要求用数学的方法来求方程的解,实际上,我们可以利用二分答案的方法来求解。

思路

二分答案和二分查找的应用很广
我们来看二分模板:

int a[100010];
int binary_search(int x,int n)
{
	int l = 1,r = n,best = -1;
	while(l <= r)
	{
		int mid = (l+r)/2;
		if(a[mid] == x)
		{
			best = mid;
			return best;
		}
		else if(a[mid] > x)
		{
			r = mid - 1;
		}
		else
		{
			l = mid + 1;
		}
	}
	return best;
}

在这段代码里面,我们利用二分查找的方法,快速查找到了XA数组里面具体的下标(1 -> n)
二分答案其实更简单一些(反正我这么觉得),二分答案的思路就是改变return的条件
上代码!

while(l < r)
{
		int mid=(l + r) / 2;
		if(check(mid)) r=mid;//在这里,是往小求得,所以往左找
		else l=mid+1;
}

学会了这个模板,就可以锦上添花的写题了

在这里 Check 函数是检查当前这个数符合不符合我们的要求,可以根据自己的需求,自己定制函数!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值