0

0

C++如何在STL中使用lower_bound和upper_bound

P粉602998670

P粉602998670

发布时间:2025-09-11 10:48:01

|

346人浏览过

|

来源于php中文网

原创

lower_bound查找第一个≥目标值的位置,upper_bound查找第一个>目标值的位置,二者配合可在有序序列中高效定位元素范围,常用于统计重复元素个数或插入位置,需保证序列有序且比较规则一致。

c++如何在stl中使用lower_bound和upper_bound

在C++的STL中,lower_boundupper_bound 是两个非常有用的算法,常用于在有序序列中进行二分查找。它们定义在 algorithm 头文件中,适用于任何支持随机访问迭代器的容器,比如 vectorarraydeque,以及 setmap 的键(自动有序)等。

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

lower_bound(first, last, value) 返回一个迭代器,指向区间 [first, last)第一个不小于 value 的元素(即 ≥ value)。如果所有元素都小于 value,则返回 last。

常见用途:查找插入位置,或查找第一个等于或大于某个值的元素。

示例:

顶级域名交易系统
顶级域名交易系统

1.后台管理登陆直接在网站地址后输入后台路径,默认为 /admin,进入后台管理登陆页面,输入管理员用户名和密码,默认为 中文 admin ,登陆后台。2.后台管理a.注销管理登陆 (离开后台管理时,请点击这里正常退出,确保系统安全)b.查看使用帮助 (如果你在使用系统时,有不清楚的,可以到这里来查看)c.管理员管理 (这里可以添加,修改,删除系统管理员,暂不支持,分权限管理操作)d.分类管理 (

下载

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

#include 
#include 
#include 

int main() { std::vector vec = {1, 3, 5, 5, 7, 9};

auto it = std::lower_bound(vec.begin(), vec.end(), 5);
if (it != vec.end()) {
    std::cout zuojiankuohaophpcnzuojiankuohaophpcn "lower_bound at index: " zuojiankuohaophpcnzuojiankuohaophpcn (it - vec.begin()) zuojiankuohaophpcnzuojiankuohaophpcn ", value: " zuojiankuohaophpcnzuojiankuohaophpcn *it zuojiankuohaophpcnzuojiankuohaophpcn '\n';
}

}

输出:
lower_bound at index: 2, value: 5

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

upper_bound(first, last, value) 返回一个迭代器,指向区间 [first, last)第一个大于 value 的元素(即 > value)。如果所有元素都 ≤ value,则返回 last。

常见用途:查找上界,配合 lower_bound 可找出某个值的范围。

示例:

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

auto it = std::upper_bound(vec.begin(), vec.end(), 5);
if (it != vec.end()) {
    std::cout << "upper_bound at index: " << (it - vec.begin()) << ", value: " << *it << '\n';
}
输出:
upper_bound at index: 4, value: 7

配合使用:查找某个值的完整范围

当序列中有重复元素时,可以使用 lower_boundupper_bound 找出值等于 value 的所有元素区间。

  • 左边界:std::lower_bound(..., value)
  • 右边界:std::upper_bound(..., value)
  • 区间 [left, right) 内的元素都等于 value

示例:统计值为 5 的元素个数

int count = std::upper_bound(vec.begin(), vec.end(), 5) - 
            std::lower_bound(vec.begin(), vec.end(), 5);
std::cout << "Count of 5: " << count << '\n'; // 输出 2

自定义比较函数

如果容器中的元素是自定义类型,或你想使用不同的排序规则,可以传入比较函数或 lambda。

例如,对降序序列使用 greater

std::vector desc = {9, 7, 5, 5, 3, 1};
auto it = std::lower_bound(desc.begin(), desc.end(), 5, std::greater());
// 注意:比较函数必须与排序规则一致

对于结构体,比如按 id 排序的 vector:

struct Person {
    int id;
    std::string name;
};

std::vector people = {{1,"A"}, {3,"B"}, {5,"C"}}; auto it = std::lower_bound(people.begin(), people.end(), 3, [](const Person& p, int value) { return p.id < value; });

基本上就这些。关键点是:序列必须有序,否则结果未定义;理解 lower 是 ≥,upper 是 >;合理使用可高效查找和统计。

相关专题

更多
golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

197

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

189

2025.07.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

338

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

542

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

53

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

197

2025.08.29

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

205

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

190

2025.11.08

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

5

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 4万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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