c++二分查找

目录

二分查找的前提

binary_search函数

lower_bound和upper_bound

例题:二分查找数组元素

题目描述

输入描述

输出描述

输入输出实例

样例输入

样例输出

解决方案

代码

运行结果


二分查找的前提

库函数只能对数组进行二分查找。

对一个数组进行二分查找的前提是这个数组中的元素是单调的,一般为单调不减。(单调不增需要修改比较函数)

例:

1,2,2,3,4\]是单调递增的;\[1,3,2,2,1\]不是单调的;\[5,5,4,3,2\]是单调的。 ## binary_search函数 binary_search函数是C++标准库中的一个算法函数,用于在已知排序的序列(数组or容器 一般是vector)中查找特定元素。 它通过二分查找算法确定序列中是否存在目标元素。 函数返回一个bool值,表示目标元素是否存在于序列中。 如果需要找到元素的位置,用std::lower_bound or std::upper_bound函数。 ## lower_bound和upper_bound 前提:数组必须为非降序 lower_bound(st,ed,x)返回地址\[st,ed)中第一个大于等于x的元素的地址。 upper_bound(st,ed,x)返回地址\[st,ed)中第一个大于x的元素的地址。 ## 例题:二分查找数组元素 ### 题目描述 给定一个数组,其采用如下代码定义: int data\[200\]; for(i=0;i\<200;i++)data\[i\] = 4\*i+6; 先给定某个数(在data数组中),请你给出它在数组中的位置。 ### 输入描述 输入一个待查找的整数(该整数一定在数组data中)。 ### 输出描述 输出该整数在数组中的指标。 ### 输入输出实例 #### 样例输入 262 #### 样例输出 64 ### 解决方案 #### 代码 ```cpp #include using namespace std; int main() { int data[200]; for (int i = 0; i < 200; i++) { data[i] = 4 * i + 6; } int target; cin >> target; cout << (lower_bound(data, data + 200, target) - data) << endl; system("pause"); return 0; } ``` #### 运行结果 ![](https://file.jishuzhan.net/article/1745431746054197249/73de41376d4bb19507663f86b5868a84.webp)

相关推荐
Laurence1 小时前
C++ 引入第三方库(一):直接引入源文件
开发语言·c++·第三方库·添加·添加库·添加包·源文件
蒸汽求职3 小时前
机器人软件工程(Robotics SDE):特斯拉Optimus落地引发的嵌入式C++与感知算法人才抢夺战
大数据·c++·算法·职场和发展·机器人·求职招聘·ai-native
charlee443 小时前
最小二乘问题详解17:SFM仿真数据生成
c++·计算机视觉·sfm·数字摄影测量·无人机航测
Tanecious.3 小时前
蓝桥杯备赛:Day4-P9749 公路
c++·蓝桥杯
旖-旎3 小时前
分治(库存管理|||)(4)
c++·算法·leetcode·排序算法·快速选择算法
Tanecious.4 小时前
蓝桥杯备赛:Day3-P1102 A-B 数对
c++·蓝桥杯
Tanecious.4 小时前
蓝桥杯备赛:Day3-P1918 保龄球
c++·蓝桥杯
良木生香4 小时前
【C++初阶】:C++类和对象(下):构造函数promax & 类型转换 & static & 友元 & 内部类 & 匿名对象 & 超级优化
c语言·开发语言·c++
三雷科技5 小时前
使用 `dlopen` 动态加载 `.so` 文件
开发语言·c++·算法
旖-旎6 小时前
分治(快速选择算法)(3)
c++·算法·leetcode·排序算法·快速选择