- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我了解到 C++
中 map
的底层数据结构是一个自平衡的二叉搜索树。由于在这些数据结构中,查找键的下限和上限有很多用处,您会认为 map lower_bound 和 upper_bound 函数将为您提供这种能力。令人遗憾的是,这些功能无法实现。有谁知道为什么 lower_bound 的行为方式是这样的? (它为您提供了不在给定 key 之前的 key )。
最佳答案
自从 SGI 甚至引入 STL 之前我就一直在使用 C++,并且出于某种原因仍然设法搞砸了使用这些方法,甚至在将它们呈现给类时让自己感到尴尬。我认为我的问题是:
这些名字在数学上已经具有直观但不同的含义。鉴于数学含义,在大集合或 map 中似乎很奇怪,upper_bound
和 lower_bound
实际上是相同或相邻的元素。
名称“upper_bound”和“lower_bound”听起来好像两者之间存在某种对称性,但实际上并非如此。如果名称类似于 least_ge
,我会轻松得多(至少大于或等于)lower_bound 和 least_gt
(最小大于)upper_bound。
如果有人有助记符或逻辑可以使这些易于内化,请分享。否则,感觉就像他们写了两个有用的函数,但使用了两个随机的数学术语来命名这些函数,无法从名称中推导出语义。到那时,为什么不使用像egptr
这样的虚构名称呢?和 pbase
?我的意思是至少我没有任何预先存在的直觉来克服关于 streambuf
的名字。方法...
无论如何,我认为这是您必须记住的基本规则:
lower_bound(X)
返回最低元素 v
这样 v >= X
upper_bound(X)
返回最低元素 v
这样 v > X
要遍历半开区间 [L,H),从 lower_bound(L)
开始并停止(不处理)lower_bound(H)
. 这通常是您想要的,因为在 C++ 中遍历半开区间是最常见的——例如,[ buf
, buf+nbytes
), 或 [ 0
, array_size
), 或 [ begin()
, end()
).
要遍历闭区间 [L,H],从 lower_bound(L)
开始并停在 upper_bound(H)
.
要遍历开区间 (L,H),从 upper_bound(L)
开始并停在 lower_bound(H)
.
在非空容器中,lower_bound(X)
的镜像是std::prev(upper_bound(X))
和upper_bound(X)
的镜像是std::prev(lower_bound(X))
.当然,如果一个元素等于begin()
, 那么你不能用 std::prev
向后退一步,所以你需要额外的逻辑来处理这个点不能用迭代器值表示的事实。
在多重集/多重映射中,第一个 v
是lower_bound(v)
如果该元素确实是 v
.最后v
是std::prev(upper_bound(v))
如果容器不为空且该元素为 v
,但记得在尝试之前检查容器是否为空 prev
在 end()
.
关于C++ 映射 lower_bound/upper_bound,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61193289/
在answers to this other question ,提供以下解决方案,由 OpenBSD 提供,为简洁起见重写, uint32_t foo( uint32_t limit ) { u
在一些 CP 竞赛中(这很重要),我使用了 2 个版本的 upper_bound 来查找我的 std::map 中的上限: 算法上限(1): auto itr = std::upper_bound(s
我下面的程序读取一个文本文件 (data.txt),使用 upper_bound() 来比较一个值,但它没有给出正确的值。我不明白为什么输出总是最后一个值。 #include #include #
假设 a 有一个可以计算为整数的类 A。 我们将 A 的 vector 作为输入,该 vector 按其 evaluate() 值排序。 如何找到评估值的上限? 我试过了,但它没有编译。 class
我是 STL 的新手,在 vector 上使用了 find() 和 upper_bound() 函数来找到 6 的位置。代码如下 #include using namespace std; int
我获得了一个在 map 顶部构建的类,具有以下K类型和V类型限制: K:可复制,可分配,小于可比性( key 并从C++ documentation of upper_bound(): templat
我了解到 C++ 中 map 的底层数据结构是一个自平衡的二叉搜索树。由于在这些数据结构中,查找键的下限和上限有很多用处,您会认为 map lower_bound 和 upper_bound 函数将为
我了解到 C++ 中 map 的底层数据结构是一个自平衡的二叉搜索树。由于在这些数据结构中,查找键的下限和上限有很多用处,您会认为 map lower_bound 和 upper_bound 函数将为
我有一个充满配对的多重 map 。我想遍历一个范围。 upper_bound 不会返回指向元素的迭代器,除非它找到第一个元素,其键大于传递给 upper_bound 的值。 我如何判断 upper_b
这个问题在这里已经有了答案: Is it defined to provide an empty range to C++ standard algorithms? (3 个答案) 关闭 8 年前。
我想找到数组中小于 K 的最大元素。我正在尝试使用 upper_bound() 函数: upper_bound(a,a+n,k, std::greater()); 对于 int a[4] = {1,
我有一个 C++ 映射,称为 tableMap,是一个 std::map . void processMap(int key) { std::map::const_iterator iter;
documentation for upper_bound状态: ...it attempts to find the element value in an ordered range [first
代码: #include "inc.h" #include #include #include #include using namespace std; class tt{ pu
Visual C++ 的 stdext::hash_set::upper_bound() 如何实现?工作? 哈希表如何让元素保持排序?! 我曾尝试阅读源代码,但很难破译 STL 代码……甚至在概念上,
我需要在组中处理类型为 Foo 的对象列表,共享对应于相同 Bar 值的质量。该列表已根据该质量进行了预先排序,因此我的想法是使用 std::upper_bound 来查找后续组的开始位置。 Bar
《C++ lower_bound()》一节中,系统地介绍了 lower_bound() 二分法查找函数的功能和用法,在此基础上,本节再讲解一个功能类似的查找函数,即 upper_bound() 函数。
我是 C++ 的新手,我正在尝试使用 lower_bound 和 upper_bound 对 vector 进行排序和搜索。这行代码对我来说是一个奇怪的错误: up = upper_bound(low
我想使用 std::upper_bound 查找某个容器中小于或等于提供值的对象范围。这使它成为一个很好的简单的单线! 问题是我只对与类的特定原始成员进行比较感兴趣。对容器进行排序没有问题,但是当我想
我是 C++ 的新手,我认为重载函数总是可以的,我的意思是: Function overloading in C++ You can have multiple definitions for the
我是一名优秀的程序员,十分优秀!