二分答案算法求教

Knock man 2020-10-04 06:04:19
二分答案算法定中间的二分mid值为什么不谈的题目会变呢,有时候是mid=(L+R)/2,有时候是mid=(L+R+1)/2;
有什么好的方法可以很好理解这个边界呢?或者有没有更好的模板
我使用的模板是这样的:
求最大值:
void solve(){
int l=0,r=MAXN;
for(int i=0;i<100;i++){
int mid = (r+l+1)/2;//这个地方到底怎么确定
if(check(mid)){
l=mid;
}else{
r=mid-1;
}
}
cout<<r<<endl;
}

求最小值:
void solve(){
int lb=0,rb=maxn;
for(int i=0;i<100;i++){
int mid=(lb+rb+1)/2;//这个地方到底怎么确定
if(check(mid)){
rb=mid;
}else{
lb=mid+1;
}
}
cout<<lb<<endl;
}

...全文
48 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
源代码大师 2021-05-08
  • 打赏
  • 举报
回复
希望对你有帮助:https://blog.csdn.net/it_xiangqiang/category_10581430.html 希望对你有帮助:https://blog.csdn.net/it_xiangqiang/category_10768339.html

64,632

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧