C++ lower_bound怎么用 C++二分查找第一个大于等于元素位置【算法】

发布时间 - 2026-01-31 00:00:00    点击率:
lower_bound返回第一个不小于给定值的迭代器;它执行二分查找,要求容器升序且支持随机访问,使用前必须检查是否等于end()以防解引用崩溃。

lower_bound 是什么,它到底返回什么

lower_bound 不是“找某个值”,而是“找第一个不小于给定值的位置”——即第一个满足 !(element 的迭代器。它不保证元素等于 value,只保证它不比 value 小。如果所有元素都小于 value,它返回末尾迭代器(比如 v.end()),这时解引用会崩溃。

常见误用:以为它一定找到相等的元素,结果拿到 v.end() 还直接 *it,触发未定义行为。

使用前必须确保容器已升序排列(默认比较规则下),否则结果无意义。它底层是二分查找,要求随机访问迭代器,所以 vectorarraydeque 可用,listforward_list 不能直接用。

基本用法和必须检查的边界

调用形式统一为:lower_bound(first, last, value),其中 firstlast 是左闭右开区间。

vector v = {1, 2, 2, 3, 4, 4, 4, 5};
auto it = lower_bound(v.begin(), v.end(), 4);
if (it != v.end()) {
    cout << "位置: " << (it - v.begin()) << ", 值: " << *it << "\n"; // 输出 4, 4
}
  • it 指向第一个 4(索引 4),不是任意一个 4
  • 如果查 6it == v.end(),此时不能解引用
  • 如果查 0it == v.begin(),合法

别省略 it != container.end() 判断——这是最常漏掉的安全检查。

自定义比较函数怎么写才不翻车

当容器不是基础类型,或你想按别的规则排序(比如降序、按结构体字段),必须传第三个参数,且要和排序时用的比较逻辑完全一致

vector> v = {{3,"a"}, {1,"b"}, {1,"c"}, {2,"d"}};
sort(v.begin(), v.end()); // 默认按 first 升序
auto it = lower_bound(v.begin(), v.end(), make_pair(1, ""), 
                      [](const auto& a, const auto& b) { return a.first < b.first; });
  • 比较函数必须是「严格弱序」:a 为真时,b 必须为假;传递性也要成立
  • 如果你用 sort(v.begin(), v.end(), greater) 降序排,那 lower_bound 也得传 greater,否则行为未定义
  • lambda 捕获列表为空即可,不要捕获局部变量后又在别处调用——lower_bound 内部会多次调用它

和 upper_bound、equal_range 的关键区别

lower_bound 找第一个 ≥,upper_bound 找第一个 >,两者夹出来的区间就是所有等于目标值的元素范围。

auto l = lower_bound(v.begin(), v.end(), 2);
auto u = upper_bound(v.begin(), v.end(), 2);
// [l, u) 就是所有值为 2 的元素
  • equal_range(value) 直接返回 pair,等价于 {lower_bound(...), upper_bound(...)},少写两行但多一次遍历(内部仍调两次二分)
  • 如果你只需要判断是否存在,用 binary_search 更语义清晰,它只返回 bool,不暴露位置
  • 不要用 lower_bound + *it == value 来判断存在性——先做指针检查再比较,否则 it == end() 时解引用就崩了

真正容易被忽略的是:所有这些算法都依赖「已排序」这个前提,而这个前提往往在插入/修改后被悄悄破坏。调试时发现 lower_bound 返回错位,第一反应不该是改比较函数,而是检查数据是否还保持有序


# c++  # 排列  # Array  # sort  # 局部变量  # 结构体  # bool  # Lambda  # 指针  # 算法  # 第一个  # 升序  # 迭代  # 的是  # 这是  # 定值  # 降序  # 遍历  # 两次  # 你想 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 香港服务器网站推广:SEO优化与外贸独立站搭建策略  打开php文件提示内存不足_怎么调整php内存限制【解决方案】  Swift中swift中的switch 语句  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  如何快速使用云服务器搭建个人网站?  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  详解vue.js组件化开发实践  Laravel集合Collection怎么用_Laravel集合常用函数详解  Laravel如何编写单元测试和功能测试?(PHPUnit示例)  Android自定义控件实现温度旋转按钮效果  Laravel如何记录自定义日志?(Log频道配置)  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  原生JS实现图片轮播切换效果  Python自动化办公教程_ExcelWordPDF批量处理案例  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  如何快速搭建高效服务器建站系统?  大同网页,大同瑞慈医院官网?  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  在Oracle关闭情况下如何修改spfile的参数  如何在Windows虚拟主机上快速搭建网站?  高端企业智能建站程序:SEO优化与响应式模板定制开发  Laravel如何使用Eloquent进行子查询  如何快速搭建支持数据库操作的智能建站平台?  用yum安装MySQLdb模块的步骤方法  Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门  Linux系统运维自动化项目教程_Ansible批量管理实战  手机软键盘弹出时影响布局的解决方法  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  javascript中的数组方法有哪些_如何利用数组方法简化数据处理  如何为不同团队 ID 动态生成多个独立按钮  Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制  Laravel如何使用Blade组件和插槽?(Component代码示例)  使用豆包 AI 辅助进行简单网页 HTML 结构设计  网站制作大概多少钱一个,做一个平台网站大概多少钱?  Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门  Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程  Laravel怎么连接多个数据库_Laravel多数据库连接配置  浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】  Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程  Android okhttputils现在进度显示实例代码  JS实现鼠标移上去显示图片或微信二维码  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  如何在云主机上快速搭建网站?  敲碗10年!Mac系列传将迎来「触控与联网」双革新  Android实现代码画虚线边框背景效果  Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程  宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  如何在局域网内绑定自建网站域名?