【C++】bitset 二进制位的有序集

本文详细介绍了C++中的bitset类,它是一个用于存储和操作二进制位的高效结构。内容包括bitset的四种构造函数,如何使用字符串进行初始化,并解释了在大小不匹配时的行为。接着,文章讨论了bitset支持的位操作符,如按位与、按位或、按位异或等,并展示了通过下标访问元素的方法。除此之外,还列举了bitset的一些实用函数,如count、flip、set、reset和test等。最后,提到了类型转换函数在bitset中的应用。
摘要由CSDN通过智能技术生成

C++的 bitset 在 bitset 头文件中,它是一种类似数组的结构,它的每一个元素只能是0或1,每个元素仅用1bit空间。

构造函数

bitset常用构造函数有四种,如下:

bitset<4> bitset1;  //无参构造,长度为4,默认每一位为0
bitset<8> bitset2(12);  //长度为8,二进制保存,前面用0补充
string s = "100101";
bitset<10> bitset3(s);  //长度为10,前面用0补充
char s2[] = "10101";
bitset<13> bitset4(s2);  //长度为13,前面用0补充
cout << bitset1 << endl;  //0000
cout << bitset2 << endl;  //00001100
cout << bitset3 << endl;  //0000100101
cout << bitset4 << endl;  //0000000010101

注意:

用字符串构造时,字符串只能包含 '0' 或 '1' ,否则会抛出异常。

构造时,需在<>中表明bitset 的大小(即size)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值