C++ lower_bound/upper_bound用法解析
2022/8/31 1:22:57
本文主要是介绍C++ lower_bound/upper_bound用法解析,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1. 作用
lower_bound和upper_bound都是C++的STL库中的函数,作用差不多,lower_bound所返回的是第一个大于或等于目标元素的元素地址,而upper_bound则是返回第一个大于目标元素的元素地址。
从定义就可以看出两者的差别只差在是否取等的的地方 那何必要设置两个函数呢(bushi
2.使用条件
用lower_bound/upper_bound进行二分查找时必须保证查找区间为升序序列!
什么是升序序列?你小学老师没教过你吗(bushi 举个例子你就明白了:
从第一个元素开始,后面的每一个元素都会大于等于前面一个元素
显然造成这种限制的原因就是出现在制作STL库的人身上 Orz,因为他所写的比较器是‘<’。
3.用法
lower_bound和upper_bound的用法与sort类似:
1 lower_bound(起始位置first,结束位置last,目标元素val); 2 upper_bound(起始位置first,结束位置last,目标元素val); 3 //lower_bound/upperbound的返回值是一个地址值,若要得到目标元素的下标,直接减去数组首地址的值即可
根据C++STL的尿性,同理可得,在lower_bound和upper_bound中我们同样可以添加cmp来进行自定义比较:
1 lower_bound(a,a+n,2,cmp); 2 upper_bound(a,a+n,2,cmp);
当然你在使用lower_bound/upper_bound时要注意其二分查找的区间:
以上面的例子为例,他们的区间都是 [a,a+n)
不要问我[)是什么,这不是小学二年级教的吗(doge,‘[’ 就是大于等于的意思,‘)’ 就是小于的意思,请举一反三。
有人可能会说了,lower_bound和upper_bound只能查找升序序列岂不是很废?那你一定是没有好好学sort ,显然,我们可以通过自定义比较函数来实现降序序列的查找:
1 bool cmp(const int& a,const int& b){ 2 return a>b; 3 } 4 lower_bound(a,a+n,val,cmp); 5 upper_bound(a,a+n,val,cmp);
或者你可以更简单一些:
lower_bound(a,a+n,val,greater<int>()); upper_bound(a,a+n,val,greater<int>());
最后,如果函数并没有找到目标元素,则会返回last的地址,且last的地址是越界的。
4.思考
https://www.luogu.com.cn/problem/P2249
这篇关于C++ lower_bound/upper_bound用法解析的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-15PingCAP 黄东旭参与 CCF 秀湖会议,共探开源教育未来
- 2024-05-13PingCAP 戴涛:构建面向未来的金融核心系统
- 2024-05-09flutter3.x_macos桌面os实战
- 2024-05-09Rust中的并发性:Sync 和 Send Traits
- 2024-05-08使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B
- 2024-05-08完工标准(DoD)与验收条件(AC)究竟有什么不同?
- 2024-05-084万 star 的 NocoDB 在 sealos 上一键起,轻松把数据库编程智能表格
- 2024-05-08Mac 版Stable Diffusion WebUI的安装
- 2024-05-08解锁CodeGeeX智能问答中3项独有的隐藏技能
- 2024-05-08RAG算法优化+新增代码仓库支持,CodeGeeX的@repo功能效果提升