首页 > 其他分享 >bitset用法

bitset用法

时间:2023-10-31 12:04:47浏览次数:39  
标签:cout 二进制位 pos 用法 bitset true string

1、简介

bitset 在 bitset 头文件中,它类似数组,并且每一个元素只能是0或1,每个元素只用1bit空间。

//头文件
#include<bitset>

2、初始化定义

初始化方法

代码 含义
bitset a a有n位,每位都为0
bitset a(b) a是unsigned long型u的一个副本
bitset a(s) a是string对象s中含有的位串的副本
bitset a(s,pos,n) a是s中从位置pos开始的n个位的副本

注意:n必须为常量表达式
演示代码:

#include<bits/stdc++.h>
using namespace std;
int main() {
	bitset<4> bitset1;    //无参构造,长度为4,默认每一位为0
	
	bitset<9> bitset2(12); //长度为9,二进制保存,前面用0补充
	
	string s = "100101";
	bitset<10> bitset3(s);  //长度为10,前面用0补充
	
	char s2[] = "10101";
	bitset<13> bitset4(s2);  //长度为13,前面用0补充
	
	cout << bitset1 << endl;  //0000
	cout << bitset2 << endl;  //000001100
	cout << bitset3 << endl;  //0000100101
	cout << bitset4 << endl; //0000000010101
	return 0;
}

3、特性

bitset可以进行位操作

bitset<4> foo (string("1001"));
bitset<4> bar (string("0011"));

cout << (foo^=bar) << endl;// 1010 (foo对bar按位异或后赋值给foo)

cout << (foo&=bar) << endl;// 0001 (按位与后赋值给foo)

cout << (foo|=bar) << endl;// 1011 (按位或后赋值给foo)

cout << (foo<<=2) << endl;// 0100 (左移2位,低位补0,有自身赋值)

cout << (foo>>=1) << endl;// 0100 (右移1位,高位补0,有自身赋值)

cout << (~bar) << endl;// 1100 (按位取反)

cout << (bar<<1) << endl;// 0110 (左移,不赋值)

cout << (bar>>1) << endl;// 0001 (右移,不赋值)

cout << (foo==bar) << endl;// false (1001==0011为false)

cout << (foo!=bar) << endl;// true  (1001!=0011为true)

cout << (foo&bar) << endl;// 0001 (按位与,不赋值)

cout << (foo|bar) << endl;// 1011 (按位或,不赋值)

cout << (foo^bar) << endl;// 1010 (按位异或,不赋值)

访问

//可以通过 [ ] 访问元素(类似数组),注意最低位下标为0,如下:
bitset<4> foo ("1011"); 

cout << foo[0] << endl;  //1
cout << foo[1] << endl;  //0
cout << foo[2] << endl;  //1

4、方法函数

代码 含义
b.any() b中是否存在置为1的二进制位,有 返回true
b.none() b中是否没有1,没有 返回true
b.count() b中为1的个数
b.size() b中二进制位的个数
b.test(pos) 测试b在pos位置是否为1,是 返回true
b[pos] 返回b在pos处的二进制位
b.set() 把b中所有位都置为1
b.set(pos) 把b中pos位置置为1
b.reset() 把b中所有位都置为0
b.reset(pos) 把b中pos位置置为0
b.flip() 把b中所有二进制位取反
b.flip(pos) 把b中pos位置取反
b.to_ulong() 用b中同样的二进制位返回一个unsigned long值

原文链接:https://blog.csdn.net/qq_50285142/article/details/114186789

标签:cout,二进制位,pos,用法,bitset,true,string
From: https://www.cnblogs.com/xiaohaigegede/p/17799915.html

相关文章

  • SQL server 中Merge Into的用法
    从备份表中更新字段到正式表中,使用UPDATE批量更新大量的数据,会出现效率低下,有时候甚至卡死的情况,后面通过使用MERGEINTO代替UPDATE执行批量更新,会提升执行效率。MERGEINTO语法如下:  MERGEINTOtable_namealias1 USING(table|view|sub_query)alias......
  • PL/SQL 基础用法
    PL/SQL基础用法数据库相关showdatabases;showtablestatus;showopentables;showcreatedatabaseleetcode;createdatabasemy_test;showdatabases;dropdatabasemy_test;数据库引擎selectdistinctenginefrominformation_schema.TABLES;createdatabasele......
  • switch-case的基本用法
    switch-case语句:我们在常常需要做出选择,选择之后往往产生不同的结果,在c语言里类似功能的语句还有if-else级联,但今天要讲的switch-case将显得更加简洁和逻辑清晰。一般格式:switch(控制表达式){case常量:语句.......case常量:......
  • Python Lambda 用法大全
    一、Lambda表达式基础Lambda的组成分为三部分lambdaarguments:expressionarguments为Lambda表达式的参数列表,多个参数使用逗号分隔;expression则是Lambda表达式的返回值表达式。Lambda表达式的基本用法:(lambdax,y:x+y)(1,2)#输出3(lambdax:x*x)(3)#输出9......
  • Linux Shell 基础 -- 总结几种括号、引号的用法
    Shell脚本中经常需要用到一些括号、引号表达式,功能各不相同,本文详细介绍一下。1、双引号""双引号常用于包含一组字符串,在双引号中,除了"$"、"\"、"`(反引号)"有特殊含义外,其余字符(如IFS、换行符、回车符等)没有特殊含义。$a=3$echo"$a"输出结果为3,在双引号中$符......
  • 反射的四种用法
    反射的总结:就是通过字符串来获取,删除和设置对象的属性或方法反射:反射是动态语言的一个重要特点,它允许你在运行时检查对象的属性和方法,以及修改它们。这为元编程和编写通用代码提供了支持。什么是反射反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问、检测和修......
  • issubclass和isinstance的用法
    issubclass(sub,super)判断第一个类是不是第二个类的的子类;是则返回True否则返回FalseclassFoo:passclassBar(Foo):pass#以元组的方式查看Bar类的所以父类print(Bar.__bases__)#这里做判断print(issubclass(Bar,Foo))print(issubclass(Foo,Bar))clas......
  • 关于mapStruct-高阶用法
    描诉:符合应用场景的实用的mapStruct对于bean映射的方法1.使用自定义转换器(Converters):如果你需要自定义映射逻辑,可以创建自定义转换器类,并使用@Mapper注解的uses属性来引用它们。这允许你在映射中使用自定义方法,以满足特定需求.@Mapper(uses={CustomConverter.class})public......
  • es查询script 用法
    在Elasticsearch中,可以使用脚本(Script)来执行自定义的逻辑和计算。脚本可以用于查询、过滤、排序等各种操作。下面是关于脚本使用语法的详细说明,并附上示例说明:脚本语言:Elasticsearch支持多种脚本语言,如Painless、Groovy等。但从Elasticsearch7.0版本开始,默认只支持Painless脚本语......
  • SQL多表联合查询用法介绍
    SQL多表联合查询用法介绍一、联合查询基本概念联合查询,又称为多表查询,是指针对两个或多个表进行查询,并将结果集合并起来展示的过程。在实际应用中,联合查询是很常见的查询方式,因为单张表无法满足复杂的查询需求。二、联合查询的语法联合查询的语法格式如下:SELECTcolumn1,co......