bitset的数据结构用法

一,bitset本质

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

类似:

bool aN;

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

二,定义 & 初始化

bitset<1000>b; //全0

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

三,基础操作

1,访问 & 修改

bi //访问

bi = 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开始

b0 是最低位

相关推荐
南境十里·墨染春水4 小时前
C++ 工厂模式:从入门到进阶,彻底掌握对象创建的艺术
开发语言·c++·算法
@insist1234 小时前
系统架构设计师-实时性评价、调度算法与内核架构选型
算法·架构·系统架构·软考·系统架构设计师·软件水平考试
workflower6 小时前
使用大语言模型处理用户需求
大数据·人工智能·设计模式·重构·动态规划
一只齐刘海的猫9 小时前
【Leetcode】找到字符串中所有字母异位词
算法·leetcode·职场和发展
海清河晏11110 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
IronMurphy11 小时前
【算法五十七】146. LRU 缓存
算法·缓存
凌波粒11 小时前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle11 小时前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
浦信仿真大讲堂12 小时前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件