0

0

C++中的std::equal_range有什么用?(同时返回有序序列的上下边界)

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-11 12:13:03

|

529人浏览过

|

来源于php中文网

原创

std::equal_range在有序序列中查找目标值的全部出现范围,返回[first, second)区间,first为首个不小于目标值的迭代器,second为首个大于目标值的迭代器;必须确保输入已排序,否则行为未定义。

c++中的std::equal_range有什么用?(同时返回有序序列的上下边界)

std::equal_range 用来找一个值在有序容器中的所有出现位置范围

它返回一对迭代器:std::pair,其中 first 是第一个不小于目标值的迭代器(等价于 std::lower_bound),second 是第一个大于目标值的迭代器(等价于 std::upper_bound)。两者合起来,就框出了所有等于该值的连续元素区间。

必须用在已排序的序列上,否则行为未定义

这是最容易踩的坑:如果传入的 [first, last) 范围没排好序,std::equal_range 的结果完全不可靠,甚至可能崩溃。它不检查排序性,只按二分逻辑跑。

  • 常见错误:对 std::vector 调用前忘了 std::sort(v.begin(), v.end())
  • 注意:自定义比较器(如 std::greater)必须和排序时用的一致
  • std::setstd::map 等关联容器天然有序,可直接用

和 lower_bound + upper_bound 手动组合相比,性能没优势但更简洁

从算法复杂度看,std::equal_range 是单次 O(log n) 二分查找,而分别调用 lower_boundupper_bound 是两次 O(log n),实际中编译器可能优化掉部分重复计算,但语义上 equal_range 更准确表达“我要整个相等区间”这个意图。

示例:

ARTi.PiCS
ARTi.PiCS

ARTi.PiCS是一款由AI驱动的虚拟头像生产器,可以生成200多个不同风格的酷炫虚拟头像

下载

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

std::vector v = {1, 2, 2, 2, 3, 4, 4};
auto range = std::equal_range(v.begin(), v.end(), 2);
// range.first  → 指向索引 1(第一个 2)
// range.second → 指向索引 4(第一个 >2 的元素,即 3)
int count = std::distance(range.first, range.second); // 得到 3

返回值是 pair,别直接解引用 second 迭代器

range.second 指向的是“超出相等范围”的位置,它本身不指向目标值。解引用 range.second 可能越界(比如目标值在末尾,second == end()),或指向别的值。真正有效的元素范围是 [range.first, range.second)

  • 安全遍历写法:for (auto it = range.first; it != range.second; ++it)
  • 不要写 *range.second,除非你先确认 range.second != v.end()
  • 空范围时 range.first == range.second,此时 distance 为 0
C++ 标准库没有提供“自动计数”或“批量修改”接口,拿到 equal_range 后具体怎么处理那块区间,得自己写循环或配合 std::erasestd::replace 等操作 —— 这部分最容易被忽略,也是业务逻辑真正开始的地方。

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

384

2023.09.04

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1011

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

60

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

363

2025.12.29

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

73

2025.09.05

golang map相关教程
golang map相关教程

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

28

2025.11.16

golang map原理
golang map原理

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

59

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

34

2025.11.27

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

78

2026.01.09

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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