C++基础算法---整数二分查找

3、整数二分查找

二分模板一共有两个,分别适用于不同情况。

算法思路:

  1. 假设目标值在闭区间[1,r]中,每次将区间长度缩小一半,当l=r时,我们就找到了目标值
  • 版本1

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

c++ 复制代码
int bsearch_1(int l ,int r)
{
   while(l<r)
   {
        int mid = (l+r)/2;
        if(check(mid)) r = mid;
        else l = mid + 1;
	}
   return l; 
}
  • 版本2

当我们将区间[1,r]划分成[1,mid-1][mid,r]时,其更新操作是r = mid-1或者1 = mid, 计算mid时需要加1。

c++ 复制代码
int bsearch_2(int l ,int r)
{
   while(l<r)
   {
        int mid = (l+r+1)/2;
        if(check(mid)) l = mid;
        else r = mid + 1;
	}
   return l; 
}
相关推荐
晨晖28 小时前
顺序查找:c语言
c语言·开发语言·算法
wadesir8 小时前
C++非对称加密实战指南(从零开始掌握RSA加密算法)
开发语言·c++
LYFlied8 小时前
【每日算法】LeetCode 64. 最小路径和(多维动态规划)
数据结构·算法·leetcode·动态规划
七禾页丫8 小时前
面试记录12 软件(c++)工程师
c++·面试·职场和发展
Salt_07289 小时前
DAY44 简单 CNN
python·深度学习·神经网络·算法·机器学习·计算机视觉·cnn
货拉拉技术9 小时前
AI拍货选车,开启拉货新体验
算法
酷酷的佳9 小时前
C语言--数组作为函数参数
c++
MobotStone9 小时前
一夜蒸发1000亿美元后,Google用什么夺回AI王座
算法
Wang201220139 小时前
RNN和LSTM对比
人工智能·算法·架构
xueyongfu9 小时前
从Diffusion到VLA pi0(π0)
人工智能·算法·stable diffusion