二分查找
1.二分查找的前提
库函数只能对数组进行二分查找。
对一个数组进行二分查找的前提是这个数组中的元素是单调的,一般为单调不减,单调不增也可以(需要修改比较函数)。
- 单调不减:单调递增但是允许相邻元素的值相同
- 单调不增:单调递减但是允许相邻元素的值相同
例如:
- [1,5,5,9,18]是单调的
- [1,9,9,7,15]不是单调的
- [9,8,8,7,7,1]是单调的
2.binary_search函数
binary_search是C++标准库中的一个算法函数,用于在已排序的序列(例如数组或容器)中查找特定元素。
它通过二分查找算法来确定序列中是否存在目标元素。
函数返回一个bool值,表示目标元素是否存在于序列中。
如果需要获取找到的元素的位置,可以使用
- std::lower_bound函数
- std::upper_bound函数
#include <bits/stdc++.h>
using namespace std;
int main() {
vector<int> numbers = {1, 3, 5, 7, 9};
int target = 5;
// 使用binary_search查找目标元素
bool found = binary_search(numbers.begin(), numbers.end(), target);
if(found) {
cout << "Target element " << target << " found." << endl;
} else {
cout << "Target element " << target << " not found." << endl;
}
// 运行结果
// Target element 5 found.
return 0;
}
3.lower_bound和upper_bound
lower_bound
和 upper_bound
是 C++ 标准库 <algorithm>
中的两个函数,用于在有序序列(比如数组或容器)中进行二分查找。它们常用于查找元素的插入位置或者查找某个范围内的元素个数。
使用前提:数组必须非降序–升序但允许相邻元素重复
如果要在非升序的数组中使用,可以通过修改比较函数实现(方法与sort自定义比较函数类似)。
- lower_bound(st, ed, x)返回地址[st, ed)中第一个大于等于x的元素的地址
- upper_bound(st, ed, x)返回地址[st, ed)中第一个大于x的元素的地址
- 如果不存在则返回最后一个元素的下一个位置,在vector中即end(),其实就是传入参数中的ed参数
注意:返回的地址-首地址(传入的st参数)=下标
#include <bits/stdc++.h>
using namespace std;
int main() {
vector<int> v = {5, 1, 7, 3, 10, 18, 9};
// 升序排序
sort(v.begin(), v.end());
// 升序输出
for(auto &i:v) cout << i << " ";
cout << "\n";
// 找到数组中第一个大于等于8的元素的位置
cout << (lower_bound(v.begin(), v.end(), 8) - v.begin()) << '\n';
/*
下标:0 1 2 3 4 5 6
值: 1 3 5 7 9 10 18
4
*/
return 0;
}