二分搜索-C

有序数组寻找不大于目标的最大值索引(左边界)

c 复制代码
// 升序
int cmp(int a, int b) {
	return a-b;
}
long searchLeft(long left, long right, int target) {
	// 1.判断[left,right)区间内是否有左边界
	if(cmp(left,target) < 0) return -1;
	// 左闭右开,有效区域[left,right)
    while(left < right) {
        long mid = left + (right -left)/2;
        // mid对应值不比目标值小,说明左边界在左侧,截断右边区域,right=mid,有效区域由[left,right)变为[left,mid)
        if(cmp(mid, target) >= 0) {
            right = mid;
        }
        // mid对应值比目标值小,说明左边界在右侧,截断左边区域,left = mid+1,有效区域由[left,right)变为[mid+1,right)
        else {
            left = mid+1;
        }
    }
    // 2.如果[left,right)区间内有左边界,在区间收敛的最后一步总是由[x,x+1)变为[x,x)或[x+1,x+1),即left==right
    return right;
}

有序数组寻找不小于目标的最小值索引(右边界)

c 复制代码
// 升序
int cmp(int a, int b) {
	return a-b;
}
long searchRight(long left, long right, int target) {
	// 1.判断[left,right)区间内是否有右边界
	if(cmp(right-1,target) > 0) return -1;
	// 左闭右开
    while(left < right) {
        long mid = left + (right -left)/2;
        // mid对应值比目标值小,说明右边界在右侧,截断左边区域,有效区域由[left,right)变为[mid+1,right)
        if(cmp(mid, target) < 0) {
            left = mid+1;
        }
        // mid对应值比目标值大,说明右边界在左侧,截断右边区域,right=mid,有效区域由[left,right)变为[left,mid)
        else if(cmp(mid, target) > 0){
            right = mid;
        }
        // mid对应值与目标值相等1.说明右边界在右侧,截断左边区域,但mid本身可能是右边界,有效区域由[left,right)变为[mid,right) 2. 在区间为[x,x+1)时,且进入此判断,下次还会进,这里增加二次进入判断。
        else {
            if(left == mid) break;
            left = mid;
        }
    }
    // 2.[left,right)区间内有右边界,在区间收敛的最后一步总是由[x,x+1)变为[x,x+1)或[x+1,x+1),left值为最终结果
    return left;
}
相关推荐
小O的算法实验室15 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
qq_3395548216 小时前
英飞凌ModusToolbox环境搭建
c语言·eclipse
张張40816 小时前
(域格)环境搭建和编译
c语言·开发语言·python·ai
郭涤生16 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿16 小时前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz17 小时前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能17 小时前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****17 小时前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能17 小时前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
独小乐17 小时前
009.中断实践之实现按键测试|千篇笔记实现嵌入式全栈/裸机篇
linux·c语言·驱动开发·笔记·嵌入式硬件·arm