数组中的二分查找函数:lower_bound【第一个 >= 目标值的元素的值或者下标】 和 upper_bound【第一个 > 目标值的元素的值或者下标】

前提:数组必须是有序的【最好是升序的】

举例:数组:[1, 2, 3, 3, 3, 7,8]查找目标值:3

lower_bound → 指向第一个 3的迭代器,解引用后可得到值

upper_bound → 指向第一个比 3 大的数(7),解引用后可得到值

【在数组中是否可以找到目标值】可执行代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N=1e4+10;
vector<int> a(N);
int main(){
a={1,2,3,3,3,7,8};
int target=5;//将要查找的值设为3. 
vector<int>::iterator ret1=lower_bound(a.begin(),a.begin()+7,target);//返回数组中第一次出现3的位置的下标。
//如果数组中没有找到这个元素,就返回数组中第一次出现大于3的位置的下标
vector<int>::iterator ret2=upper_bound(a.begin(),a.begin()+7,target);//返回数组中第一次出现大于3的位置的下标 
cout<<*ret1<<endl<<*ret2<<endl;
if(target==*ret1) cout<<"在数组中可以找到目标值:"<<target<<endl;
else cout<<"在数组中不可以找到目标值"<<endl;
}

运行结果:

lower_bound -a.begin()→ 指向第一个 3的下标

upper_bound -a.begin()→ 指向第一个比 3 大的数(7)的下标

【得到目标值第一次出现的下标和目标值最后一次出现下标的下一个位置】可执行代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N=1e4+10;
vector<int> a(N);
int main(){
a={1,2,3,3,3,7,8};
int target=3;//将要查找的值设为3. 
int ret1=lower_bound(a.begin(),a.begin()+7,target)-a.begin();//返回数组中第一次出现3的位置的下标。
//如果数组中没有找到这个元素,就返回数组中第一次出现大于3的位置的下标
int ret2=upper_bound(a.begin(),a.begin()+7,target)-a.begin();//返回数组中第一次出现大于3的位置的下标 
cout<<ret1<<endl<<ret2;
}

运行结果:

【修改一下,将目标值改为数组中未出现的元素时lower_bound()和upper_bound()函数值的变化】可执行代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N=1e4+10;
vector<int> a(N);
int main(){
a={1,2,3,3,3,7,8};
int target=5;//将要查找的值设为5. 
int ret1=lower_bound(a.begin(),a.begin()+7,target)-a.begin();//返回数组中第一次出现3的位置的下标。
//如果数组中没有找到这个元素,就返回数组中第一次出现大于5的位置的下标
int ret2=upper_bound(a.begin(),a.begin()+7,target)-a.begin();//返回数组中第一次出现大于5的位置的下标 
cout<<ret1<<endl<<ret2;
}

运行结果:

相关推荐
crediks2 小时前
MTGR(美团生成式推荐框架)总结文档
人工智能·深度学习·算法
im_AMBER2 小时前
Leetcode 143 搜索插入位置 | 搜索二维矩阵
数据结构·算法·leetcode
小年糕是糕手2 小时前
【35天从0开始备战蓝桥杯 -- Day5】
数据结构·数据库·c++·算法·蓝桥杯
bbbb3652 小时前
算法优化的多层缓存映射与访问调度模型的技术7
算法
Fleshy数模3 小时前
多分类任务下的经典机器学习算法实战:LR、RF、SVM等对比分析
算法·机器学习·分类
风吹乱了我的头发~6 小时前
Day52:2026年3月20日打卡
算法
2401_8318249611 小时前
基于C++的区块链实现
开发语言·c++·算法
We་ct11 小时前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
愣头不青11 小时前
238.除了自身以外数组的乘积
数据结构·算法