Binary_Search(搜索)pars向量
Binary_Search on vector of pars
我试图在一对向量上执行二进制排序,并且一旦找到迭代器也返回,但是我似乎对此有问题。一开始是这样的t是int类型的向量
if (std::binary_search(t.begin(), t.end(), 5, *it))
{
if (it != t.end())
{
cout << "FOund";
}
}
然而,这似乎不起作用(编译问题)我认为这个问题是因为我有一对而不是法向量,所以想知道是否有人有任何网站链接在这个我可以阅读?# #
收到错误如下:
term不能求值为带有两个参数的函数
标准算法std::binary_search有以下形式
template<class ForwardIterator, class T>
bool binary_search(ForwardIterator first,
ForwardIterator last,
const T& value);
template<class ForwardIterator, class T, class Compare>
bool binary_search(ForwardIterator first,
ForwardIterator last,
const T& value,
Compare comp);
因此你在语句
中调用算法if (std::binary_search(t.begin(), t.end(), 5, *it))
和后续检查
if (it != t.end())
没有意义。此外,如果向量的值类型为std::pair
,则必须指定std::pair
类型的对象作为第三个参数。
您应该使用std::lower_bound
或std::equal_range
来代替std::binary_search
。
你到底想干什么?如何在对数组中查找一个整数?你只能在一对向量中找到一个给定的对。
如果你想找到一个以整数作为第一个或第二个参数的对,你必须自己写一些代码。
要查找给定的对,请继续阅读
std::binary_search
不能返回迭代器,也不接受迭代器作为第四个形参。作为第四个参数,它接受一个比较器,但你的it
肯定不是比较器。
如果你想获得一个迭代器,你应该使用std::lower_bound
或std::upper_bound
,并且将返回值赋给it
: it = std::lower_bound(t.begin(), t.end(), val)
。
相关文章:
- 写入向量<向量<bool>>
- 函数向量_指针有不同的原型,我可以构建一个吗
- std::向量与传递值的动态数组
- 将值指定给向量(2D)的向量中的某个位置
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 如何使用向量的template_back函数
- 尝试通过多个向量访问变量时,向量下标超出范围
- 如何通过派生类函数更改基类中的向量
- C++从另一个类访问公共静态向量的正确方法是什么
- 如何将ampl中的集合表示为c++中的向量
- 变量没有改变?通过向量的函数调用
- 迭代时从向量和内存中删除对象
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 如何为模板化对象创建模板向量?VS正在投掷C3203
- 计算排序向量的向量中唯一值的计数
- 矩阵向量乘法(cublasDgemv)返回零
- 一对向量构造函数:初始值设定项列表与显式构造
- 将结构向量排序为子组
- 在C++中调整向量中的索引
- Binary_Search(搜索)pars向量