有没有办法汇总数组的位位置



假设我有一个像 [1,2,3] 这样的数组,它们对应的位值是 [0001, 0010, 0011]

我想得到一个数组来记住它们的位位置,因为 ar[4] = {0,0,2,2}。

我能想到的唯一方法是使用 bitsetto_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;
}

最新更新