二分算法查找模板

这个是acwing站长YXC的模板
https://www.acwing.com/file_system/file/content/whole/index/content/3073/

版本1
当我们将区间[l, r]划分成[l, mid]和[mid + 1, r]时,其更新操作是r = mid或者l = mid + 1;,计算mid时不需要加1。

C++ 代码模板:
int bsearch_1(int l, int r)
{
    while (l < r)
    {
        int mid = l + r >> 1;
        if (check(mid)) r = mid;
        else l = mid + 1;
    }
    return l;
}
版本2
当我们将区间[l, r]划分成[l, mid - 1]和[mid, r]时,其更新操作是r = mid - 1或者l = mid;,此时为了防止死循环,计算mid时需要加1。

C++ 代码模板:
int bsearch_2(int l, int r)
{
    while (l < r)
    {
        int mid = l + r + 1 >> 1;
        if (check(mid)) l = mid;
        else r = mid - 1;
    }
    return l;
}

这个是《算法竞赛进阶指南》的模板 对于check函数也进行了描述

保证答案处于闭区间[l,r]以内,循环以l=r结束
在单调递增序列a中查找>=x的数中最小的一个(即x或x的后继)
while(l<r){
  int mid = l+r>>1;
  if(a[mid]>=x) r=mid;else l = mid+1;
}
return a[l];

在单调递增序列a中查找<=x的数中最大一个(即x或者x的前驱)
while(l<r){
  int mid = (l+r+1)>>1;
  if(a[mid]<=x) l= mid;else r =mid-1;
}
return a[l];

我的视频题解空间

posted on   itdef  阅读(33)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话
历史上的今天:
2021-01-16 挑战程序设计竞赛 2.1章习题 Aizu - 0558 Cheese BFS

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示