首页 > 其他分享 >bitset详解以及用法

bitset详解以及用法

时间:2024-06-18 13:00:09浏览次数:11  
标签:运算 取反 用法 位数 详解 b1 b2 bitset

butset详解以及用法

bitset是C++ 标准库中的一个类,它提供了一种方便的方式来操作位序列,常用于位运算和状态压缩。下面我将为您详细介绍 bitset 的基本概念、基本用法以及一些常用的成员函数。

基本概念

1、bitset 可以看作是一个多位二进制数,其每一位都是 0 或 1。
2、它是一个固定大小的容器,可以存储指定数量的位。
3、由于 bitset 支持基本的位运算,因此它非常适合用于状态压缩和表示一组布尔值。

基本用法

定义

bitset<N> b; // 定义一个 N 位的 bitset,所有位初始化为 0

N是正整数表示bitset的大小

位运算操作符

1、~b:对 b 中的每一位取反。
2、b1 & b2、b1 | b2、b1 ^ b2:对两个位数相同的 bitset 执行按位与、或、异或运算。
3、b << n、b >> n:将 b 左移或右移 n 位(右侧或左侧补零)。
4、b1 == b2、b1 != b2:比较两个位数相同的 bitset 是否相等。

访问和修改位

b[k]:访问或修改 b 的第 k 位(从 0 开始计数)。

成员函数

1、b.count():返回 b 中设置为 1 的位数。
2、b.any():如果 b 中至少有一位为 1,则返回 true;否则返回 false。
3、b.none():如果 b 中的所有位都为 0,则返回 true;否则返回 false。
4、b.set():将 b 中的所有位设置为 1。
5、b.set(k, v):将 b 的第 k 位设置为 v(v 为 true 或 false)。
6、b.reset():将 b 中的所有位设置为 0。
7、b.reset(k):将 b 的第 k 位设置为 0。
8、b.flip():将 b 中的所有位取反。
9、b.flip(k):将 b 的第 k 位取反。
10、b.to_ulong()、b.to_ullong():将 bitset 转换为 unsigned long 或 unsigned long long 类型的整数(注意转换时的位数限制)。

类型转换

1、数字转换为 bitset:将数字转换为二进制,并存储在 bitset 中。如果数字的二进制位数小于 bitset 的大小,则在前面补零;如果大于 bitset 的大小,则只取最低的 N 位。
2、字符串转换为 bitset:字符串只能包含 0 和 1,否则会报错。

注意事项

1、bitset 的长度是固定的,在定义时需要指定。
2、bitset 适用于小规模的位运算和状态压缩,如果规模较大,可能需要考虑其他数据结构或方法。
3、bitset 底层是通过数组来实现的,每个元素占用 1 位空间,但每 8 位(一个字节)实际上会占用一个字节的存储空间。

标签:运算,取反,用法,位数,详解,b1,b2,bitset
From: https://blog.csdn.net/2301_80662593/article/details/139770067

相关文章

  • 【JVM】详解双亲委派机制
    双亲委派机制是Java类加载器的一种工作模式,确保类加载的一致性和安全性。以下是详细的定义、优缺点以及如何破坏双亲委派机制的描述。双亲委派机制的定义双亲委派机制(ParentDelegationModel)是一种类加载器的工作模式。在这种模式下,类加载器在加载类时,会先将加载请求委派......
  • 【名词解释】Unity3D物理射线(Physics Ray)含义及其用法
    Unity3D是一款流行的游戏开发引擎,它提供了一套强大的工具和功能来帮助开发者创建交互式3D内容。在Unity中,"物理射线"(PhysicsRay)通常指的是使用射线检测(Raycasting)来检测物体之间的碰撞或者检测射线与物体的交点。这在游戏开发中非常常见,用于实现如射击、视线检测、物体碰撞检......
  • Typora高级用法
    闲来无事,原本想给typora做一个ai接口的,但是突然发现,下载的人好像都特别喜欢搞创新和升级,现在的typora真的说真的升级的越来越牛了看我界面,一种高级感嘿哈是不是很牛的,所以写一篇文章来记录一下。下载插件的网址https://codeload.github.com/obgnail/typora_plugin/zip/refs......
  • 好用的库函数,qsort函数大详解(干货满满!)(进阶)
    前言:  小编在上一篇文章说了这一篇将要写qsort函数的模拟实现,那么废话不多说,现在开始进入今天的代码之旅喽!目录:1.qsort函数的模拟实现的逻辑和思路2.qsort函数模拟实现的代码实现3.代码展示1.qsort函数的模拟实现的逻辑和思路  读者朋友们是否还记得小编之前说过......
  • Redis常见数据类型及其常用命令详解
    文章目录一、Redis概述二、Redis常用命令1.通用命令1.1KEYS:查看符合模板的所有key1.2DEL:删除一个指定的key1.3EXISTS:判断key是否存在1.4EXPIRE:给一个key设置有效期,有效期到期时该key会被自动删除1.5TTL:查看一个key的剩余有效期1.6COPY:复制Redis数据库......
  • JMeter 响应断言详解:提升测试精度的利器
    前言在性能测试和功能测试中,响应断言是验证系统响应是否符合预期的重要手段。ApacheJMeter提供了丰富的断言功能,帮助测试工程师确保测试请求的响应数据正确、可靠。本文将详细介绍JMeter中响应断言的类型、配置方法以及最佳实践。什么是响应断言?响应断言用于验证JMeter发......
  • 精准控制:Python 输入数值范围限制详解
    前言在实际开发过程中,经常需要对用户输入的数值进行限制,以确保输入的数据在合理的范围内。这不仅能防止程序错误,还能提高用户体验。作为一名测试工程师,掌握如何在Python中限制输入数值范围是非常有用的技能。本文将详细介绍如何使用Python实现这一功能,包括基础方法和高级应用......
  • 多模态大模型:识别和处理图片与视频的技术详解
    随着人工智能和深度学习技术的快速发展,多模态大模型在识别和处理图片与视频方面展现出了强大的能力。多模态大模型能够处理多种形式的数据,包括文本、图像、视频、音频等,从而实现更智能、更全面的理解与应用。本文将详细介绍多模态大模型是如何识别和处理图片与视频的。1.......
  • MySQL约束详解:构建数据完整性基石
    目录MySQL约束1.1约束1.1数据类型1.2主键约束[`重要`]1.3自增约束1.4唯一约束1.5非空约束1.6默认值代码演示1.7外键约束[了解]思维导图最后MySQL约束MySQL作为广泛使用的开源关系型数据库管理系统,其强大的数据约束功能对于维护数据的一致性和准确性至关重......
  • Windows ipconfig命令用法简单介绍
    windows的图形界面操作起来很舒服,但是有时候不熟悉的话又会比较难操作,因此通过一定的命令行可以帮助我们完成网络配置和故障排除,Windowsipconfig命令无疑是一个不错的工具。本次就来简单讲述一下ipconfig命令的各种用法和技巧,帮助你更好地管理和优化你的网络连接,以及应对电脑有......