bitset 用法

转自: http://blog.csdn.net/lbird/article/details/1605833


 bitset 类简化了位集的处理,有些程序要使用二进制位的有序集来保存一组项或条件的标志位,可以考虑使用bitset

需要的文件:

#include <bitset>

Using std::bitset

l         bitset 对象的定义和初始化

定义bitset时,要明确bitset有多少位:

bitset<32> bitvec     // 32位二进制,初始化为0,0~31

unsigned 值初始化bitset 对象:

当用unsigned 值初始化bitset 对象时,该值将转化为二进制的位模式。如果bitset类型长度大于 unsigned 值的二进制位数,则其余的高阶位将置为0;如果bitset 类型长度小于unsigned 值的二进制位数,则只使用unsigned值中的低阶位,超过bitset类型长度的高阶位将被丢弃。

bitset<16> bit ( 0xFFFF )              // 0~15位都置1

bitset<32> bit ( 0xFFFF )              // 0~15位置1,16~31位置0

用 string 对象初始化bitset对象

string strval ( “1100” )

bitset<32> bit ( strval )

注意:从string对象读入位集的顺序是从右向左。即反向转化:string对象最右边的字符用来初始化bitset对象的低阶位(即下标为0的位)。

bit 的位模式中第2和3位置为1,其余位置都为0。如果string对象的字符个数小于bitset类型的长度,则高阶位将置为0。

       不一定要把整个string对象都作为bitset的初始值,可以只用某个子串作为初始值:

string str ( “111111111100000000011011” )

bitset<32> bit ( str , 5 , 4 )

l         bitset的成员函数

any()             是否存在位置为1的二进制位

none()          不存在置为1的二进制位?

count()         置为1的二进制位的个数

size()            总的二进制位的个数

[pos]            访问在pos处的二进制位

test(pos)     pos处的二进制位是否为1

set()             所有位都置1

set(pos)              pos处的二进制置1

reset()         所有二进制置0

reset(pos)   pos处的二进制位置0

flip()             所有位置反

flip(pos)              pos位置反

to_ulong()   返回一个 unsigned long 值

os<<b           位集输出到os流

参考: 《 C++  Primer》


bitset是C++中的一个标准库,用于位运算和位存储操作。它可以将一组位(0和1)看作是一个整体,并提供了一些方法来操作这个整体。 以下是bitset类的一些常用方法: 1. 构造函数 bitset有多个构造函数,其中最常用的是接受一个整数作为参数的构造函数。例如: ```c++ bitset<8> bits(0b10101010); ``` 这将创建一个包含8位的bitset对象,其中的位序列为10101010。 2. 大小 可以使用size()函数获取bitset对象中位的数量,例如: ```c++ bitset<8> bits(0b10101010); cout << bits.size() << endl; // 输出8 ``` 3. 操作符 bitset类重载了许多操作符,可以使用这些操作符对位进行操作。例如: ```c++ bitset<8> bits1(0b10101010); bitset<8> bits2(0b01010101); // 位与操作 bitset<8> result = bits1 & bits2; cout << result << endl; // 输出00000000 // 位或操作 result = bits1 | bits2; cout << result << endl; // 输出11111111 // 位异或操作 result = bits1 ^ bits2; cout << result << endl; // 输出11111111 // 取反操作 result = ~bits1; cout << result << endl; // 输出01010101 ``` 4. 访问位 可以使用[]操作符访问bitset对象中的位,例如: ```c++ bitset<8> bits(0b10101010); cout << bits[0] << endl; // 输出0 cout << bits[1] << endl; // 输出1 ``` 5. 设置和重置位 可以使用set()函数将位设置为1,使用reset()函数将位重置为0,例如: ```c++ bitset<8> bits(0b10101010); bits.set(0); cout << bits << endl; // 输出10101011 bits.reset(1); cout << bits << endl; // 输出10101001 ``` 这些只是bitset类的一些常用方法,更多方法可以查看官方文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值