用于展平容器容器的泛型函数

Generic function to flatten a container of containers

本文关键字:泛型 函数 用于      更新时间:2023-10-16

我正在努力更好地掌握迭代器和泛型函数。我认为编写一个将container1 < container2 <type> >转换为container3 <type>的函数将是一个有用的练习。例如,它应该能够将vector< deque<int> >转换为list<int>

我认为所有的容器访问都应该通过迭代器,就像<algorithm>中的函数一样。

这是我的代码:

#include <iterator>
#include <algorithm>
// COCiter == Container of Containers Iterator
// Oiter == Output Iterator
template <class COCiter, class Oiter>
void flatten (COCiter start, COCiter end, Oiter dest)
{
    using namespace std;
    while (start != end) {
        dest = copy(start->begin(), start()->end(), dest);
        ++start;
    }
}

但当我尝试用以下代码调用它时:

int main ()
{
    using namespace std;
    vector< vector<string> > splitlines;
    vector<string> flat;
    /* some code to fill SPLITLINES with vectors of strings */
    flatten(splitlines.begin(), splitlines.end(), back_inserter(flat));
}

我收到一条巨大的C++模板错误消息,undefined reference to void flatten< ... pages of templates ...

我觉得我的代码太容易写了,我必须需要更多的东西来确保内部容器中的数据类型与输出容器中的类型匹配。但我不知道该怎么办。

我发现了这个问题。由于SFINAE(替换失败不是错误),您的编译器找不到正确的模板,因为您正试图通过键入start()(可能是拼写错误)在start上调用operator()。试试这个:

#include <iterator>
#include <algorithm>
// COCiter == Container of Containers Iterator
// Oiter == Output Iterator
template <class COCiter, class Oiter>
void flatten (COCiter start, COCiter end, Oiter dest) {
    while (start != end) {
        dest = std::copy(start->begin(), start->end(), dest);
        ++start;
    }
}

std::accumulate可以为您做到这一点。您需要将每个内部向量的内容聚集到外部向量中。

vector<vector<int>> v_of_v;
vector<int> v = std::accumulate(
    v_of_v.begin(), v_of_v.end(),
    vector<int>(),
    [](vector<int> a, vector<int> b) {
        a.insert(a.end(), b.begin(), b.end());
        return a;
    });