std::bitset 数组作为 return 值

array of std::bitset as a return value

我需要编写一个函数来对两个 std::bitset 执行 N 个不同的布尔运算符,在每个 运行 程序中可以有不同的大小。所以我尝试编写一个函数来执行内部操作和 return 位集数组,但我不知道我应该如何定义 return 值?

template<size_t SIZE>
    ....  bitwiseOperator(bitset<SIZE> r_1, bitset<SIZE> r_2, vector<int> fun)
    {
      int  k = 0;
      bitset<SIZE> r_12;
      const int N =   fun.size();
      bitset<SIZE> rs[N];
      for(vector<int>::iterator it = fun.begin(); it != fun.end(); ++it) 
      {
        if (*it == 1)         
        {
                r_12 = r_1 & r_2;
        }
        else if(*it == 2)  
        {
                r_12 = r_1 | r_2;
        }
        else if(*it == 3) 
        {
                r_12 = r_1 ^ r_2;
        }
        rs[k] = r_12;
        k++;
     }
        return rs;
    }

我需要 return 值类似于 bitset[N]

您想要 return 可变大小数组的事实建议使用 std::vector.

所以我可能会这样做:

template<size_t SIZE>
std::vector<std::bitset<SIZE> > bitwiseOperator(bitset<SIZE> r_1,
    bitset<SIZE> r_2, vector<int> fun)
{
    int k = 0;
    bitset<SIZE> r_12;

    const int N = fun.size(); // not sizeof(fun); !!!

    std::vector<std::bitset<SIZE> > rs(N); // Variable size suggests std::vector

    for(vector<int>::iterator it = fun.begin(); it != fun.end(); ++it)
    {
        if(*it == 1)
        {
            r_12 = r_1 & r_2;
        }
        else if(*it == 2)
        {
            r_12 = r_1 | r_2;
        }
        else if(*it == 3)
        {
            r_12 = r_1 ^ r_2;
        }
        rs[k] = r_12;
        k++;
    }
    return rs;
}