0

在查找算法中使用范围适配器时,我必须重复所有适配器链以获取相应的 end() 迭代器。例如:

std::vector<size_t> numbers = { 10, 11, 12, 13, 14, 2, 1, 3,3,50, 55} ;

if ( find(numbers|reversed,99) != (numbers|reversed).end() )
                                 //^adaptor chain repeated
{
    std::cout << "FOUND!!!!!" << std::endl;
}

有没有办法得到相应的结束迭代器而不必再次重复?

4

1 回答 1

1

太糟糕了,find调用通常会变得冗长——使用 STL 比使用 Boost 范围更糟糕。你可以引入一个小辅助函数:

template<class SinglePassRange, class Value>
bool contains(SinglePassRange& rng, Value const &val) {
  return boost::find(rng, val) != rng.end();
}

我没有对此进行测试,所以它可能无法编译,但你明白了。

于 2017-06-12T16:08:25.840 回答