2

我想将函数返回的范围连接成一个大范围。考虑以下代码:

some_type_i_cant_figure_out bar() {
    typedef std::vector<int>::const_iterator iter;
    std::vector<int> aaa;
    /* fill some data into aaa*/
    some_type_i_cant_figure_out cc;
    for (int i = 0; i < aaa.size(); ++i) {
    std::pair<iter, iter> bbb = foo(aaa, i);
    ccc = boost::join(ccc, bbb);
    }
    return ccc;
}

我要实现
的目标: aaa 向量很大, foo 可能会返回很大的范围。当然,我可以将范围内所有元素的副本创建到新的整数向量中并返回它。它效率低下,浪费内存和时间。所以我想返回一个 boost::joined_range。在最坏的情况下,我可以使用范围向量,但它太简单而且不那么优雅:) 除了joined_range 不是默认可构造的(这对于这个示例实现来说是一个问题)返回值类型是什么?临时变量(ccc)类型以及实现上述目标的正确和优雅的方法是什么?

4

1 回答 1

1

首先,您的代码的最终结果似乎类似于

auto cc(aaa);
boost::stable_sort(cc);

(假设,从您的示例代码中,它aaa包含范围内的整数[0..size()-1)

如果您负担得起简单的复制,只需使用反向插入迭代器:

std::vector<int> cc;
for (size_t i = 0; i < aaa.size(); ++i)
    boost::copy(boost::equal_range(aaa, i), back_inserter(cc));

否则,您可以使用以下命令隐藏累积连接any_range

boost::any_range<int, boost::forward_traversal_tag, int> r;
for (size_t i = 0; i < aaa.size(); ++i)
    r = boost::join(r, boost::equal_range(aaa, i));

Live On Coliru

#include <boost/range/any_range.hpp>
#include <boost/range/join.hpp>
#include <boost/range/algorithm.hpp>
#include <iostream>

int main() {
    std::vector<int> const aaa { 1,1,1,4,5,5,9,42,42,42,42,42,42 };

    boost::any_range<int, boost::forward_traversal_tag, int> r;
    for (size_t i = 0; i < aaa.size(); ++i)
        r = boost::join(r, boost::equal_range(aaa, i));

    boost::copy(r, std::ostream_iterator<int>(std::cout << "result: ", " "));
}

印刷

result: 1 1 1 4 5 5 9
于 2014-11-19T09:07:48.067 回答