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] 是最低位

相关推荐
hoiii1875 小时前
粒子滤波跟踪系统 - 蒙特卡洛方法实现
算法
weisian1516 小时前
Java并发编程--47-分布式ID生成器:雪花算法(Snowflake)与时钟回拨问题
java·算法·时钟回拨·雪花算法id
itzixiao6 小时前
L1-066 猫是液体(5分)[java][python]
java·开发语言·python·算法
ytttr8736 小时前
MATLAB SIFT图像配准实现
算法·机器学习·matlab
小饕6 小时前
从 Word2Vec 到多模态:词嵌入技术的演进全景
人工智能·算法·机器学习
海参崴-6 小时前
AVL树完整实现与深度解析
算法
一个爱编程的人6 小时前
一个数是不是素数
数据结构·算法
Hui_AI7206 小时前
基于RAG的农产品GEO溯源智能问答系统实现
开发语言·网络·人工智能·python·算法·创业创新
lwf0061646 小时前
FFM (Field-aware Factorization Machine) 学习日记
算法·机器学习