0

0

c++怎么使用位集bitset_c++ bitset位操作用法详解

下次还敢

下次还敢

发布时间:2025-10-23 11:01:02

|

1042人浏览过

|

来源于php中文网

原创

bitset是C++中用于高效操作固定长度二进制序列的模板类,定义在<bitset>头文件中,支持位运算、状态压缩和集合模拟等场景。1. bitset的模板参数为编译时确定的位数,可使用默认值、整数或字符串初始化,其中字符串初始化按从左到右对应高位到低位。2. 提供test、set、reset、flip等成员函数进行位访问与修改,count返回1的个数,any和none判断是否存在或全无置位,to_string和to_ulong实现类型转换。3. 支持按位取反、与、或、异或及移位运算,适用于相同大小的bitset间操作。4. 常用于权限管理、集合操作模拟和1的个数统计,具有高可读性和性能优势。

c++怎么使用位集bitset_c++ bitset位操作用法详解

在C++中,bitset 是一个非常实用的模板类,定义在 <bitset> 头文件中,用于高效地操作固定长度的二进制位序列。它适合进行位运算、状态压缩、布尔标志管理等场景。相比使用整型变量手动进行位操作,bitset 提供了更直观、安全和可读性更强的接口。

1. bitset 的基本定义与初始化

bitset 的模板参数是固定的位数,必须在编译时确定。

示例:

  • bitset<8> b1; // 默认初始化为全0:00000000
  • bitset<8> b2(255); // 用整数初始化:11111111
  • bitset<8> b3("11001010"); // 用字符串初始化:11001010
  • bitset<16> b4(string("1010")); // 用 string 对象初始化

注意:字符串初始化时,顺序是从右往左对应低位到高位,但写字符串时按正常顺序从左到右写即可。

立即学习C++免费学习笔记(深入)”;

2. 常用成员函数与操作

bitset 提供了一系列方法来访问和修改位、转换类型或查询属性。

  • test(pos):检查第 pos 位是否为1(从0开始),返回 bool。
  • set(pos):将第 pos 位设为1;set(pos, 0) 设为0。
  • reset(pos):将第 pos 位设为0;reset() 全部清零。
  • flip(pos):翻转第 pos 位;flip() 翻转所有位。
  • count():返回值为1的位的个数。
  • size():返回总位数。
  • any():是否有任意一位为1。
  • none():是否所有位都为0(与 !any() 等价)。
  • to_string():转换为字符串。
  • to_ulong():转换为 unsigned long(超出范围抛出异常)。
  • to_ullong():转换为 unsigned long long。

示例代码:

Napkin AI
Napkin AI

Napkin AI 可以将您的文本转换为图表、流程图、信息图、思维导图视觉效果,以便快速有效地分享您的想法。

下载
bitset<8> b("10101010");
cout << b.test(0) << endl; // 输出 0
cout << b.count() << endl; // 输出 4
b.set(0); // 设置第0位为1
cout << b.any() << endl; // 输出 1
cout << b.to_string() << endl; // 输出 "10101011"

3. 支持的位运算操作

bitset 支持常见的位运算符,可用于两个相同大小的 bitset 之间操作。

  • ~b:按位取反
  • b1 & b2:按位与
  • b1 | b2:按位或
  • b1 ^ b2:按位异或
  • b << n:左移 n 位(右边补0)
  • b >> n:右移 n 位(左边补0)

示例:

bitset<8> a("1100"), b("1010");
cout << (a & b) << endl; // 输出 1000
cout << (a | b) << endl; // 输出 1110
cout << (a << 2) << endl; // 输出 110000

4. 实际应用场景举例

状态压缩:比如表示一组开关状态、权限位等。

// 表示8个权限位,第0位为读权限,第1位为写权限...
bitset<8> perms;
perms.set(0); // 赋予读权限
perms.set(1); // 赋予写权限
if (perms.test(0)) cout << "有读权限\n";

集合操作模拟:小范围整数集合可用 bitset 模拟交并补。

bitset<10> setA("101010"); // 包含元素 1,3,5
bitset<10> setB("110100"); // 包含元素 2,3,5
cout << (setA & setB).to_string(); // 交集:元素3,5

快速统计奇偶性、1的个数:利用 count() 方法。

基本上就这些。bitset 使用简单,性能高,是 C++ 中处理位相关问题的推荐工具

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1051

2023.08.02

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1570

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

241

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

150

2025.10.17

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6.1万人学习

ASP 教程
ASP 教程

共34课时 | 5.9万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号