常见 二分查找

经典问题:

在一个严格递增序列中A找到给定的数x的下标

left,right为整个序列的下标区间,每次测试比较预查询的x与中间位置Amid的大小

1.若x == Amid 说明查找成功,返回mid

2.若x < Amid 说明x在mid的左侧,因此right = mid-1;

3.若x > Amid 说明x在mid的右侧,因此left = mid + 1;

循环的条件为left <= right

当然若A序列为递减,同理。

值得注意的是:若二分查找上界超过int类型范围的一半,并且预查询元素在序列靠后的位置,mid = (left+right)/2 很可能超过int而导致溢出。因此mid 可以写成 mid = left + (right-left)/2

进一步的问题:

若递增序列A中的元素允许重复,那么对于给定的预查询元素x,求出序列中第一个大于等于x元素的位置。

与之前的查找类似,不过在条件上有些许不同

1.若x == Amid 那么第一个大于等于x的元素的范围肯定在left,mid

2.若x > Amid 范围在mid+1,right

3.若x < Amid 范围在left,mid,这个得注意,可以举个例子3,5,8x = 4,Amid = 5,那么第一个大于等于x应该是5

该问题的循环条件是left < right 而不是left <= right,对于该问题想要返回第一个大于等于x的元素的位置,不需要判断元素x本身是否存在,因此只需left,right left==right时就会刚好夹出唯一的位置,因此条件为left <right

这里可以将数组an的输入为0,n,那么当x大于数组的所有元素0\~n-1,那么就输出n,表示没有该元素。

相关推荐
数智工坊1 分钟前
周志华《Machine Learning》学习笔记--第六章--支持向量机
笔记·神经网络·学习·算法·机器学习·支持向量机
casual~3 分钟前
【学习记录】
学习·算法
社交怪人6 分钟前
【奇偶ASCII值】信息学奥赛一本通C语言解法(题号1042)
算法
牛油果子哥q7 分钟前
【C++指针与引用】C++指针与引用底层彻底精讲:本质区别、易错深坑、底层内存模型、工程选型、笔试面试满分解析
c++·面试
我登哥MVP11 分钟前
Spring Boo从“会用”到“精通”:Spring Boot 入门
java·spring boot·后端·spring·maven·intellij-idea·mybatis
染翰16 分钟前
Java 实现 Git 自动克隆工具,打包成 Windows 独立 EXE(免安装JDK)
java·git·后端
十五年专注C++开发21 分钟前
CMake实践:VS2019控制台程序隐藏控制台方法
c++·windows·cmake·控制台隐藏
七老板的blog24 分钟前
多阶段 AI 评测流水线架构设计与实践
java·人工智能·spring
小欣加油24 分钟前
leetcode3635 最早完成陆地和水上游乐设施的时间II
数据结构·c++·算法·leetcode
qq_4581482030 分钟前
科大讯飞实时语音识别(rtasr)真实项目踩坑经验总结与手把手教学真实可运行Demo
java·开发语言·websocket·语音识别