可以解决这个问题?
假设我有一个像 [1,2,3] 这样的数组,它们对应的位值是 [0001, 0010, 0011]
我想得到一个数组来记住它们的位位置,因为 ar[4] = {0,0,2,2}。
我能想到的唯一方法是使用 bitset
的to_string
将值传输到位字符串。 然后使用 stoi
迭代并添加到数组中。 这是相当复杂的,有没有更好的方法
我想你正在寻找这样的东西。我不确定你为什么需要to_string
,除非我从你的描述中遗漏了一些东西。
#include <iostream>
#include <bitset>
#include <vector>
int main()
{
const int num_bits = sizeof(int) * 8;
std::vector<int> values = { 1,2,3 };
int result[num_bits] = {};
std::bitset<num_bits> bits;
for (size_t i = 0; i < values.size(); ++i)
{
bits = values[i];
for (int bit = 0; bit < num_bits; ++bit)
{
result[bit] += bits[bit];
}
}
for (auto num : result)
{
std::cout << num << " ";
}
std::cout << "n";
return 0;
}