lower_bound in C++ minus vector
lower_bound in C++ minus vector
下面的代码有什么作用?
for (i = 1; i <= n; i++)
v[i] = std::lower_bound(prim+1, prim+h+1, val[i]) - prim;
其中prim
、v
和val
是整数的向量。
我认为你的描述是错误的,prim
是一个迭代器或指针而不是一个向量。
此行取 lower_bound
的返回值,该值与迭代器的类型相同,并减去该迭代器。这为您提供了prim
引用的容器的索引。
你应该从阅读函数lower_bound的作用开始:http://www.cplusplus.com/reference/algorithm/lower_bound/
在这种情况下,对于向量 v[] 中的每个元素 v[i],我们找到一个向量的 prim[] 索引 k,其值最低,其中 prim[k]>=val[i]。
相关文章:
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- 在c++中用vector填充一个简单的动态数组
- vector.resize()中的分配错误
- 使用std::vector的OpenCL矩阵乘法
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- 在某些循环内使用vector.push_back时出现分段错误
- 当vector是tje全局变量时,c++中vector的内存管理
- std::vector的包装器,使数组的结构看起来像结构的数组
- 为什么(-1)%vector::size()总是返回0
- 在C++中将类(带有Vector成员)保存为二进制文件
- 编译器如何区分std::vector的构造函数
- 将 int 数组转换为 std::vector<int*>
- 使用 pqxx 将 std::vector 存储在 postgresql 中,并从数据库中检索它
- 在std::vector上存储带有模板的类实例
- 在main()之外初始化std::vector会导致性能下降(多线程)
- 为什么std::vector比数组慢
- std::vector::迭代器是否可以合法地作为指针
- 如何将二进制格式的 C++ 对象的 std::vector 保存到磁盘?
- 循环中的条件:为什么每次都调用strlen(),而vector.size()只调用一次
- lower_bound in C++ minus vector