bitset在c++之中对于需要按位操作的情况很好用

本文介绍了 C++ 中 bitset 类的基本概念与使用方法。详细讲述了 bitset 的定义、声明方式,以及各种操作函数,例如 count、size、test、any、none、all、flip、set 和 reset 等。此外,还提供了如何将 bitset 转换为 string 或 unsigned long 类型的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、bitset是什么
bitset是c++中的一个类库,来管理一系列bit位,及二进制串。类似于数组,但每个元素只能是0或1且仅用1bit的空间
包含于头文件#include < bitset >;中

二、使用方法
1、定义申明:
1.bitset<4> a; //申请一个名为a长度为4的bitset,默认每位为0
2.bitset<8> b(12); //长度为8,将12二进制保存在b中,前面位补0
3.string s = "10010";
  bitset<10> c(s);  //长度为10,将s二进制保存在c中,前面位补0

cout << a << endl; //0000
cout << b << endl; //00001100
cout << c << endl; //0000010010
 

用字符串构造时,字符串只能包含0、1
在进行有参构造时,若参数的二进制表示比bitset的size小,则在前面用0补充(如上);若比bitsize大,参数为整数时取后面部分;参数为字符串时取前面部分
访问bitset时可用[ ]访问它的每一位,如a[0]、b[3];0为其最低位
2、相关使用函数
bitset<8> s("10011011");

s.count();    //5 返回s中1的个数,s中有5个
s.size();    //8 返回s的位数,s为8位
s.test(0);    //true 检查下标为0的元素(最低位)是0还是1,0返回flase,1返回true
s.any();    //true 检查s中是否有1
s.none();    //flase 检查s中是否没有1
s.all();    //flase 检查s中是否全为1

s.filp();    //01100100 不传参则将s的每一位取反
s.filp(2);    //10011111 传参则将s的下标为2处取反
s.set();    //11111111 不传参则将s的每一位 置1
s.set(3);    //10011011 传一个参数将s的下标为3的位 置1
s.set(3,0);    //10010011 传两个参数将s的下标为3的位 置0(第二个参数)
s.reset();    //00000000 不传参则将s的每一位 置0
s.reset(3);    //10010011 传参则将s的下标为3的位 置0

转换函数:

bitset<8> t("10011011");

string s = t.to_string();    //将t转换成string型
unsigned long a = t.to_ulong();    //将t转换成unsigned long型
unsigned long long b = t.to_ullong();    //将t转换成unsigned long long型
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值