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;
}
我需要编写一个函数来对两个 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;
}