c++中的upper_bound()和lower_bound()的使用

本文介绍C++中使用upper_bound()和lower_bound()函数进行高效查找的技巧,详细解释了这两个函数的参数设置及应用场景,通过实例代码展示了如何查找数组中特定数值的位置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

c++中的upper_bound()和lower_bound()的使用

c++中通过upper_bound()和lower_bound()寻找数组中某一个数值的位置,主要包含三个参数:

1.一个数组元素的地址(或者数组名来表示这个数组的首地址,用来表示这个数组的开头比较的元素的地址,不一定要是首地址,只是用于比较的“首”地址),

2.一个数组元素的地址(对应的这个数组里边任意一个元素的地址,表示这个二分里边的比较的"结尾’地址),

3.就是一个你要查找的那个数。

上代码:
#include
#include<stdio.h>
#include
#include
#include
#pragma warning(disable:4996)

using namespace std;
int k, n = 10;
int a[10] = { 1,1,1,3,3,5,5,5,5,6 };

//lower_bound()
//int main()
//{
// for (int i = 0; i < n; i++)cout << a[i] << " “;
// cout << endl;
// while (scanf(”%d", &k))
// {
// cout << k << “的第一个大于等于它的位置在” << ((lower_bound(a, a + n, k)) - a) + 1 << endl;
// }
//}

//upper_bound()

int main()
{
for (int i = 0; i < n; i++)cout << a[i] << " “;
cout << endl;
while (scanf(”%d", &k))
{
cout << k << “的第一个大于它的位置在” << ((upper_bound(a, a + n, k)) - a) + 1 << endl;
}
}
其中lower_bound()是要查找数大于等于的位置,upper_bound()是大于数组里面某个数的位置。具体代入上述代码自己验证,对于做查找很方便。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值