bitset详解

bitset详解bitset 常见用法详解 bitset

大家好,欢迎来到IT知识分享网。

主页面目录

10 bitset

10.1 介绍

bitset 在 bitset 头文件中,它类似数组,并且每一个元素只能是0或1,每个元素只用1bit空间

//头文件 #include<bitset> 

10.2 初始化定义

初始化方法

代码 含义
bitset<n> a a有n位,每位都为0
bitset<n> a(b) a是unsigned long型u的一个副本
bitset<n> a(s) a是string对象s中含有的位串的副本
bitset<n> a(s,pos,n) a是s中从位置pos开始的n个位的副本

注意:n必须为常量表达式

演示代码:

#include<bits/stdc++.h> using namespace std; int main() { 
    // 1 无参构造 bitset<4> bitset1; //无参构造,长度为4,默认每一位为0 // 2 有参构造:数字作为参数 bitset<9> bitset2(12); //长度为9,将该数转化为二进制保存,前面用0补充 // 或此写法 bitset<9> bitset2({12}); // 3 有参构造:string字符串作为参数  string s = ""; bitset<10> bitset3(s); //长度为10,前面用 0 补充 // 4 有参构造:char字符数组(字符串)作为参数  char s2[] = "10101"; bitset<13> bitset4(s2); //长度为13,前面用 0 补充 cout << bitset1 << endl; //0000 cout << bitset2 << endl; //000001100 cout << bitset3 << endl; //0000 cout << bitset4 << endl; //0000000010101 return 0; } 

10.3 特性

bitset可以进行位操作

bitset<4> foo (string("1001")); bitset<4> bar (string("0011")); cout << (foo ^= bar) << endl;// 1010 (foo对bar按位异或后赋值给foo) cout << (foo &= bar) << endl;// 0001 (按位与后赋值给foo) cout << (foo |= bar) << endl;// 1011 (按位或后赋值给foo) cout << (foo <<= 2) << endl;// 0100 (左移2位,低位补0,有自身赋值) cout << (foo >>= 1) << endl;// 0100 (右移1位,高位补0,有自身赋值) cout << (~bar) << endl;// 1100 (按位取反) cout << (bar << 1) << endl;// 0110 (左移,不赋值) cout << (bar >> 1) << endl;// 0001 (右移,不赋值) cout << (foo == bar) << endl;// false (1001==0011为false) cout << (foo != bar) << endl;// true (1001!=0011为true) cout << (foo & bar) << endl;// 0001 (按位与,不赋值) cout << (foo | bar) << endl;// 1011 (按位或,不赋值) cout << (foo ^ bar) << endl;// 1010 (按位异或,不赋值) 

访问

//可以通过 [] 访问元素(类似数组),注意最低位下标为0,类似于数的二进制表示,如下: bitset<4> f("1011"); for (int i = 0; i < 4; ++i) { 
     cout << f[i]; } // 输出1101 

注意: bitset访问时候是从右边(最低位)开始访问的,但是左右移位的时候还是按照原来的形式左右移位的


10.4 方法函数

代码 含义
b.any() b中是否存在置为1的二进制位,有 返回true
b.none() b中是否没有1,没有 返回true
b.count() b中为1的个数
b.size() b中二进制位的个数
b.test(pos) 测试b在pos位置是否为1,是 返回true
b[pos] 返回b在pos处的二进制位
b.set() 把b中所有位都置为1
b.set(pos) 把b中pos位置置为1
b.reset() 把b中所有位都置为0
b.reset(pos) 把b中pos位置置为0
b.flip() 把b中所有二进制位取反
b.flip(pos) 把b中pos位置取反
b.to_ulong() 用b中同样的二进制位返回一个unsigned long值

10.5 bitset优化

一般会使用bitset来优化时间复杂度,大概时间复杂度会除64或32,例如没有优化的时间复杂度为 O ( N M ) O(NM) O(NM) ,使用bitset优化后复杂度可能就为 O ( N M 64 ) O(\frac{NM}{64}) O(64NM)

bitset还有开动态空间的技巧,bitset常用在01背包优化等算法中

// 动态长度bitset实现 const int N = 1e6 + 5; // 开空间的上限,一般为数据范围附近的值 template <int len = 1> void bitset_(int sz) { 
      // sz即为想要开的大小 if (len < sz) { 
      bitset_<min(len * 2, N)>(sz); return; } bitset<len + 1> dp; // 具体算法的实现 } 

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/119918.html

(0)
上一篇 2025-11-02 09:20
下一篇 2025-11-02 09:33

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信