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

一、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型
 

  • 5
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在给定的代码中,我们可以看到在函数int main()中使用了bitset类。该类用于表示二进制位的集合。在引用中,bitset对象b1和b2被创建,分别初始化为字符串bit_string的副本。对于b2,它从位置5开始,取4个位,并用'0'和'1'来替代0和1。然后,我们可以使用下标运算符来访问bitset中的特定位。 要获取bitset对象b中的第六位,我们可以使用下标运算符[]来访问该位。在引用的代码中,我们可以看到对b2[i和b3[i的访问,它们都是取特定位的例子。因此,在代码中取bitset第六位的方法是b[i,其中i是位的索引。请注意,根据C++的约定,索引从0开始,因此在取第六位时,索引应该是5。 因此,在给定的代码中,要取bitset对象b的第六位,可以使用b来实现。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [C++ bitset](https://blog.csdn.net/weixin_45940369/article/details/131074219)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [c++bitsetbitset函数](https://blog.csdn.net/JIAN_ZANG1125/article/details/120644729)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值