bitset的数据结构用法

一,bitset本质

bitset = 定长二进制数组(0/1)+ 位运算加速

类似:

bool a[N];

支持批量位运算(64位/128位并行)

二,定义 & 初始化

bitset<1000>b; //全0

bitset<1000>b("10101"); //字符串初始化(低位在左)

三,基础操作

1,访问 & 修改

b[i] //访问

b[i] = 1; //修改

2,清空 / 置1

b.reset(); //全0

b.set(); //全1

b.set(i); //第i位 = 1

b.reset(i); //第i位 = 0

3,取反

~b

b.flip(); //全部翻转

b.flip(i); //单点翻转

4,统计

b.count() // 1 的个数

b.any() // 是否有1

b.none() // 是否全0

b.all() // 是否全1

四,位运算

1,与(交集)

c = a & b;

2,或(并集)

c = a | b;

3,异或

c = a ^ b;

4,位移

b << k

b >> k

复杂度优势

普通做法:

O(n)

bitset:

O(n / 64)

注意事项

必须定长

bitset<n> //n必须是常量

下标必须从0开始

b[0] 是最低位

相关推荐
我爱cope几秒前
【力扣hot100:53. 最大子数组和】
算法·leetcode·职场和发展
Dlrb12119 小时前
C语言-指针三
c语言·算法·指针·const·命令行参数
Tisfy9 小时前
LeetCode 2540.最小公共值:双指针(O(m+n))
算法·leetcode·题解·双指针
IronMurphy9 小时前
【算法四十七】152. 乘积最大子数组
算法
淘矿人10 小时前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops
Cosolar10 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
落羽的落羽12 小时前
【算法札记】练习 | Week4
linux·服务器·数据结构·c++·人工智能·算法·动态规划
萑澈13 小时前
算法竞赛入门:C++ STL核心用法与时空复杂度速查手册
数据结构·c++·算法·stl
Godspeed Zhao13 小时前
从零开始学AI16——SVM
算法·机器学习·支持向量机