stl算法中不同类型的严格弱排序

时间:2012-05-16 11:37:12

标签: c++ stl c++11

我有一个类定义了与其他类型的严格弱排序,我想在该类的容器上使用基于比较的算法(例如std :: upper_bound)。

标准定义容器的forward iterator值类型应该是可比类型的类型,因此以下内容不能编译:

template<typename T>
class Foo {
public:
    bool operator<(const T& _val) { return val < _val; }
    //operator T() { return val; } // uncommenting this solves the problem
private:
    T val;
};

void bar() {
    vector<Foo<int>> foos(10);
    auto i_lb = std::lower_bound(foos.begin(), foos.end(), 17); // compiles and works, though I don't know why
    auto i_eq = std::equal_range(foos.begin(), foos.end(), 17); // error! not convertible to int
}

我找不到使用接受谓词的算法版本的方法(也要求类型相同)。定义转换运算符使此示例有效,但定义一个并不总是正确的。进行这种比较的正确方法是什么?

顺便说一句,用std :: lower_bound替换std :: equal_range有效,但我无法弄明白为什么。

1 个答案:

答案 0 :(得分:2)

equal_range必须比较两种方式的值,以确定它们是否相等

  

a

时,值b被视为与另一个值(!(a<b) && !(b<a))等效

lower_bound只需找到范围的一端。

您的比较仅适用于Foo < T,而不适用于T < Foo