5

我正在慢慢学习boost,并试图找到一种简单的方法来转换以下 C++ 片段:

for(int i=-n;i<n+1;i++) {
  for(int j=-n;j<n+1;j++) {
     for(int k=-n;k<n+1;k++) {
       cout << i << ' ' << j << ' ' << k << endl;
     }
  }
}

进入一个我可以循环的迭代器。用我的母语python(我可以这样称呼它吗?),这是一个单线使用itertools

itrtools.product(range(-n,n+1),repeat=3)

一个完整的答案将提供一个最小的工作示例和文档链接,以便我可以 RTFM。

4

1 回答 1

3

Boost.Preprocessor可以BOOST_PP_SEQ_FOR_EACH_PRODUCT在预处理步骤中执行此操作

BOOST_PP_SEQ_FOR_EACH_PRODUCT 宏为几个 seq 的每个笛卡尔积重复一个宏。

但我想这不是你要找的。

如果一些可重用的代码没问题,那么您可以使用Boost.Iterator中的函数输入迭代器来生成给定范围的笛卡尔积。

发电机

class product_generator
{
    public:
        typedef std::vector<int> result_type;

        product_generator (int lower, int upper, unsigned int repeat)
            : m_lower(lower), m_upper(upper)
        {  
            for(unsigned int i = 0; i < repeat; ++i)
            {  
                m_iters.push_back(m_lower);
            }
        };

        std::vector<int> operator() ()
        {  
            for(int& i : m_iters)
            {  
                if(++i >= m_upper)
                    i = m_lower;
                else
                    break;
            }

            std::vector<int> res;
            for(int i : m_iters)
                res.push_back(i);

            return res;
        };

    private:
        int m_lower;
        int m_upper;
        std::vector<int> m_iters;
};

使用此生成器,您可以执行以下操作:

product_generator p(lower, upper, repeat);
auto bgn = boost::make_function_input_iterator(p, (double)0);

bgn是单个迭代器,您可以循环该迭代器以生成由输入范围形成的输入序列的笛卡尔积。

一个完整的工作示例:

#include <vector>
#include <iostream>
#include <boost/iterator/function_input_iterator.hpp>
#include <math.h>

int main ()
{
    int lower = 1;
    int upper = 4;
    unsigned int repeat = 3;

    product_generator p(lower, upper, repeat);

    for(   
            auto bgn = boost::make_function_input_iterator(p, (double)0);
            bgn != boost::make_function_input_iterator(p, pow(upper-lower, repeat));
            ++bgn
       )
    {  
        for(int i : *bgn)
        {  
            std::cout << i << " ";
        }
        std::cout << std::endl;
    }
}
于 2012-06-01T19:49:12.497 回答