3.二分查找

二分查找

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_boundupper_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;
} 
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值