如何对字符串执行按位或运算?
A:
10001
01010
------
11011为什么是在字符串上?位的长度可以是40-50。这在int上可能会有问题吗?有什么想法吗?
发布于 2010-03-30 19:51:14
我想说,对于您的情况,std::bitset已经足够了,但是为了获得更大的灵活性,您可以使用boost::dynamic_bitset。下面是一个关于std::bitset的示例
const size_t N = 64;
string a_str = "10001", b_str = "01010";
bitset<N> a(a_str), b(b_str);
bitset<N> c = a | b;
cout << c;发布于 2010-03-30 19:47:36
您应该看一看C++ std::bitset类,它做的正是您想要的。
发布于 2010-03-30 19:48:10
为什么不直接使用int值的vector呢?bitset不是仍然使用每位一个字节吗?
您也可以使用bool值的vector,但这也是特定于实现的。
根据您是否需要存储效率或速度(或者这些方法中的一些方法所缺少的容器方法的效用),您可能需要配置文件来决定使用哪种方法。
https://stackoverflow.com/questions/2544809
复制相似问题