查找排序区域中元素数量的最快方法是什么?
What's the fastest way to find the number of elements in a sorted range?
给定排序列表1, 3, 5, 6, 9....
假设所有数字都是整数,是否有一种快速算法而不是O(n)
来计算给定范围[a, b]
中的元素数量?
这里有一个O(logn)算法:使用二进制搜索来搜索两个端点,范围内的元素数量基本上就是索引的差异。
要获得确切的数字,需要区分范围的端点是否在数组中的情况。
由于列表是排序的,您可以在O(log(n))时间内找到值的位置(或者,如果值不在列表中,则可以找到它应该插入的位置)。只需对两端执行此操作,然后相减即可获得该范围内的元素数。元素是否为整数没有区别;只需要对列表进行排序。
如果元素不是唯一的,您确实需要小心;在这种情况下,在找到命中后,您可能需要对重复元素序列的末尾进行线性扫描。
lower_bound
和upper_bound
对已排序的容器进行操作。
首先在该范围中找到较低的值,然后从那里搜索到最后查找较高的值。函数的实现可能使用二进制搜索:
#include <algorithm>
#include <list>
#include <iterator>
int main() {
using std::list;
using std::upper_bound;
using std::lower_bound;
using std::distance;
list<int> numbers = {1, 3, 5, 6, 9};
int a = 3;
int b = 6;
auto lower = lower_bound(numbers.begin(), numbers.end(),
a);
auto upper = upper_bound(lower, numbers.end(),
b);
int count = distance(lower, upper);
return 0;
}
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 通过JNI传递数据数组的最快方法是什么
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用不同的CRT将新的C++代码与旧的(二进制)组件隔离开来的最佳方法是什么
- 当无法使用模板和宏时,生成类型变体C++代码的最简单方法是什么?
- 在另一个类视图中添加最多2个图表的正确方法是什么
- 在C++中样板"冷/never_inline"错误处理技术的最佳方法是什么?
- 在 c++ 中对类中的 c 字符串动态数组进行排序的最佳方法是什么?
- 在C++中包含原型文件的正确方法是什么?
- 在 OpenCV C++ 中估计基本矩阵之前对相应点进行归一化的正确方法是什么?
- 在PostgreSQL中根据它们的ID选择大量行的最快方法是什么?
- 在OSX上使用CMake将Adobe的XMP工具包构建为共享库的最简单方法是什么?
- 将一系列整数放入类的最佳方法是什么?
- 从长整整转换为uint64_t的推荐方法是什么?
- 将此布尔值传递给此函数的最有效方法是什么?
- 通过比较C++中的行在 txt 文件中搜索的最简单方法是什么?