C++:位集无法正常工作
C++: bitset doesn't work properly
我的项目需要一个std::bitset<64>
。但在打印数字时出现了问题:
unsigned long long var = 18446462598732906495ULL;
std::cout << std::bitset<64>(var) << std::endl;
它打印:
0000000000000000000000000000000000000000000000001111111111111111
我希望它能打印:
1111111111111111000000000000000000000000000000001111111111111111
出了什么问题?
我在64位机器上使用DevC++。
您使用的bitset
构造函数采用unsigned long
而不是unsigned long long
,因此编译器可能会丢弃不适合unsigned long
的位。我认为您将不得不对输入值进行迭代,并单独设置位。
据我所见,在C++98中,位集有3个构造函数,其中一个是无符号长(在Windows 64中为32位)。
但是!在C++11中,它被纠正了,构造函数现在有无符号的long-long作为参数(在Windows 64上是64位)。
因此,更改您的设置以使用C++11标准
http://www.cplusplus.com/reference/bitset/bitset/bitset/
相关文章:
- QSqlquery prepare()和bindvalue()不工作
- 导入库可以跨dll版本工作吗
- 以螺旋方式打印矩阵的程序.(工作不好)
- 对象指针在c++中是如何工作的
- 为什么在Windows上的VS 2019和Clang 9中"size_t"在没有标题的情况下工作
- VSOMEIP-2个设备之间的通信(TCP/UDP)不工作
- 为字符串中每 N 个字符插入空格的函数没有按照我认为的方式工作?
- C++为线程工作动态地分割例程
- 为什么我的 std::ref 无法按预期工作?
- 布尔比较运算符是如何在C++中工作的
- SampleConsensusPrerejective(ext.RANSAC)是如何真正工作的
- 不确定要在我的main中放入什么才能使我的代码正常工作
- 为什么std::condition_variable notify_all的工作速度比notify_one快(对于随机请
- <<操作员在下面的行中工作
- 有人能解释一下为什么下界是这样工作的吗C++的
- ExtractIconEx:可以工作,但偶尔会崩溃
- C++中的memset函数工作不正常
- 当我在第一个循环中使用"auto"时,它工作正常,但是使用"int"它会给出错误,为什么?
- 为什么STD ::计数将常数传递给Lambda,而不是在弦上工作时而不是字符
- C++程序已停止工作-求解常微分方程