前言
在上一篇博客内我大概讲了一下二分
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;
}
在这段代码里面,我们利用二分查找的方法,快速查找到了X
在A
数组里面具体的下标(1 -> n)
二分答案其实更简单一些(反正我这么觉得),二分答案的思路就是改变return的条件
上代码!
while(l < r)
{
int mid=(l + r) / 2;
if(check(mid)) r=mid;//在这里,是往小求得,所以往左找
else l=mid+1;
}
学会了这个模板,就可以锦上添花的写题了
在这里 Check 函数是检查当前这个数符合不符合我们的要求,可以根据自己的需求,自己定制函数!