首页 > 后端开发 > C++ > 正文

c++中std::lower_bound和std::upper_bound的用法 _c++二分查找算法使用技巧

裘德小鎮的故事
发布: 2025-10-30 14:47:07
原创
549人浏览过
std::lower_bound找≥目标值的第一个位置,std::upper_bound找>目标值的第一个位置,二者结合可计算有序序列中元素出现次数,均需有序区间并支持自定义比较函数。

c++中std::lower_bound和std::upper_bound的用法 _c++二分查找算法使用技巧

在C++中,std::lower_boundstd::upper_bound 是两个非常实用的二分查找算法,定义在 algorithm 头文件中。它们用于在已排序的区间中快速定位元素的位置,常用于优化查找性能,尤其是在处理大量有序数据时。

std::lower_bound:查找第一个不小于目标值的位置

std::lower_bound(first, last, value) 返回一个迭代器,指向区间 [first, last)第一个不小于 value 的元素位置。换句话说,它找到的是第一个满足 ≥ value 的元素。

常见用途:

  • 判断某个值是否存在或插入位置
  • 统计有序数组中 ≥ 某个值的最小下标

示例:

立即学习C++免费学习笔记(深入)”;

法语写作助手
法语写作助手

法语助手旗下的AI智能写作平台,支持语法、拼写自动纠错,一键改写、润色你的法语作文。

法语写作助手31
查看详情 法语写作助手
vector<int> nums = {1, 2, 4, 4, 5, 7, 9};
auto it = std::lower_bound(nums.begin(), nums.end(), 4);
// it 指向第一个 4,下标为 2

std::upper_bound:查找第一个大于目标值的位置

std::upper_bound(first, last, value) 返回指向区间中第一个大于 value 的元素的迭代器。即找到第一个满足 > value 的位置。

典型场景:

  • 确定某个值在有序序列中的“上界”
  • 配合 lower_bound 计算某个值的出现次数

示例:

立即学习C++免费学习笔记(深入)”;

vector<int> nums = {1, 2, 4, 4, 5, 7, 9};
auto it = std::upper_bound(nums.begin(), nums.end(), 4);
// it 指向 5,下标为 4

结合使用:统计元素出现次数

对于有序数组中重复元素的计数,可以利用这两个函数:

int count = std::upper_bound(nums.begin(), nums.end(), x)
- std::lower_bound(nums.begin(), nums.end(), x);

这段代码计算了值 x 在数组中出现的次数。因为:

  • lower_bound 找到第一个 x 的位置
  • upper_bound 找到第一个 > x 的位置
  • 两者之差就是 x 的频次

自定义比较函数(支持降序和结构体)

默认情况下,这两个函数使用 < 比较,适用于升序排列。如果容器是降序,或者你想用自定义规则,可以传入比较函数或 lambda。

例如,对降序数组使用:

vector<int> nums = {9, 7, 5, 4, 4, 2, 1}; // 降序
auto it = std::lower_bound(nums.begin(), nums.end(), 4, std::greater<int>());
// 使用 greater 表示按 > 判断,找到第一个 ≤ 4 的位置(实际是第一个 4)

也可以用 lambda 实现更复杂的逻辑。

基本上就这些。只要记住:lower_bound 找 ≥,upper_bound 找 >,且都要求数据有序。合理使用能大幅提高查找效率,避免手写二分出错。不复杂但容易忽略细节。

以上就是c++++中std::lower_bound和std::upper_bound的用法 _c++二分查找算法使用技巧的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号