c – 使用多个输入向量中的值的笛卡尔积来调用lambda

前端之家收集整理的这篇文章主要介绍了c – 使用多个输入向量中的值的笛卡尔积来调用lambda前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有几个int或double的向量:
std::vector<int>    iv = { 1,2,3,4 };
std::vector<double> jv = { .5,1.,1.5,2. };
std::vector<int>    kv = { 5,4,2 };

我需要处理每个向量的笛卡尔积:

for (int i : iv)
{
    for (double j : jv)
    {
        for (int k : kv)
        {
            process(i,j,k);
        }
    }
}

我想把它变成一个电话

product(iv,jv,kv,[=](int i,double j,int k)
    {
        process(i,k);
    });

>输入向量的数量是可变的
>存储在输入向量中的类型是可变的

这可能吗? (我正在使用C 14)

解决方法

这是一个简短的递归版本,只适用于任何迭代.它通过const& amp;为简单起见:
template <typename F>
void product(F f) {
    f();
}

template <typename F,typename C1,typename... Cs> 
void product(F f,C1 const& c1,Cs const&... cs) {
    for (auto const& e1 : c1) {
        product([&](auto const&... es){
            f(e1,es...);
        },cs...);
    }   
}

这将是:

product(process,iv,kv);

猜你在找的C&C++相关文章