是否可以使用STL算法重写我的代码?

问题描述 投票:0回答:1

我有一个嵌套循环,我希望使用STL算法重写它。有人可以帮我吗?

std::bitset<array_size * 8> bitset {};
short bitsetIndex {0};
for (int i = 0; i < array_size; ++i) {
    std::bitset<8> cBitset { (unsigned char) charArray[i] };
    for (int i = 0; i < cBitset.size(); ++i) {
        if(cBitset.test(i)) {
            bitset.set(bitsetIndex);
        }
        bitsetIndex++;
    }
}
return bitset;
c++ stl-algorithm
1个回答
1
投票

似乎您想将charArray表示为位的集合。一个简单的循环和几个位操作即可完成工作:

using Bitset = std::bitset<array_size * 8>;
Bitset bitset;
for (auto i = array_size; i > 0; --i) {
    bitset <<= 8;
    bitset |= Bitset(static_cast<unsigned char>(charArray[i - 1]));
}
return bitset;

取决于charArray是什么,循环也可以用迭代器重写:

using Bitset = std::bitset<array_size * 8>;
Bitset bitset;
for (auto it = std::rbegin(charArray); it != std::rend(charArray); ++it) {
    bitset <<= 8;
    bitset |= Bitset(static_cast<unsigned char>(*it));
}
return bitset;

最后,如果您确实要使用某些标准库算法,则可以使用std::accumulate

std::accumulate

using Bitset = std::bitset<array_size * 8>; return std::accumulate(std::rbegin(charArray), std::rend(charArray), Bitset{}, [](Bitset bs, auto ch) { return (bs << 8) | std::bitset<array_size * 8>(static_cast<unsigned char>(ch)); });

© www.soinside.com 2019 - 2024. All rights reserved.