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,触发未定义行为。
使用前必须确保容器已升序排列(默认比较规则下),否则结果无意义。它底层是二分查找,要求随机访问迭代器,所以 vector、array、deque 可用,list 或 forward_list 不能直接用。
基本用法和必须检查的边界
调用形式统一为:lower_bound(first, last, value),其中 first 和 last 是左闭右开区间。
vectorv = {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 - 如果查
6,it == v.end(),此时不能解引用 - 如果查
0,it == 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氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
如何在局域网内绑定自建网站域名?

