STL中bitset的用法
终于又来写博客了 ==
bitset存储的是二进数位,就和一个bool性数组差不多。用法上和数组的操作方式也差不多。
每位只占一个字节,大大优化了空间,可以通过数组形式访问。
bitset定义
可以用以下几种方式定义bitset,值得注意的是,bitset在定义的时候必须定义大小,这里8便是我们定义的长度,定义一个空bitset时所有值默认为0;
- bitset<> b;
- bitset<> bit();
- bitset<> tp1(string(""));
- bitset<> tp2(bit);
- cout << " b = " << b << endl;
- cout << "bit = " << bit << endl;
- cout << "tp1 = " << tp1 << endl;
- cout << "tp2 = " << tp2 << endl;
上面代码的输出结果为
- b =
- bit =
- tp1 =
- tp2 =
bitset的运算
猜都能猜到bitset肯定是支持位运算的,是的bitset可以直接做位运算
- bitset<> tp1(string(""));
- bitset<> tp2(string(""));
- cout << "(tp1 & tp2) = " << (tp1 & tp2) << endl;
- cout << "(tp1 | tp2) = " << (tp1 | tp2) << endl;
- cout << "(tp1 ^ tp2) = " << (tp1 ^ tp2) << endl;
- cout << "(~tp1) = " << (~tp1) << endl;
- cout << "(tp1 &= tp2) = " << (tp1 &= tp2) << endl;
- cout << "(tp1 |= tp2) = " << (tp1 |= tp2) << endl;
- cout << "(tp1 ^= tp2) = " << (tp1 ^= tp2) << endl;
- cout << "(tp1 <<= 1) = " << (tp1 <<= ) << endl;
- cout << "(tp1 ^= tp) = " << (tp1 ^= ) << endl;
- cout << "(tp1 == tp2) = " << (tp1 == tp2) << endl;
- cout << "(tp1 != tp2) = " << (tp1 != tp2) << endl;
这就没什么好说的了,运行结果为
- (tp1 & tp2) =
- (tp1 | tp2) =
- (tp1 ^ tp2) =
- (~tp1) =
- (tp1 &= tp2) =
- (tp1 |= tp2) =
- (tp1 ^= tp2) =
- (tp1 <<= ) =
- (tp1 ^= tp) =
- (tp1 == tp2) =
- (tp1 != tp2) =
bitset的函数
既然也是STL的东西,肯定会封装了一下函数,bitset是没有迭代器的。
常用函数有
- bit.size(); //返回大小(长度)
- bit.count(); //返回1的个数
- bit.any(); //返回是否有1
- bit.none(); //返回是否没有1
- bit.set(); //全部置为1
- bit.set(p); //将p+1(下标从0开始!!)位置为1
- bit.set(p,n); //将p+1位置为n
- bit.reset(); //全部置为0
- bit.reset(p); //将p+1位置为0
- bit.flip(); //全部取反 等同于 (~bit)
- bit.flip(p); //将p+1位取反
- bit.to_ulong(); //返回转换为 unsigned long 的结果,超范围会报错
- bit.to_ullong();//返回转换为 unsigned long long 的结果,超范围报错
- bit.to_string();//返回转换为 string 的结果
当题目涉及到位运算时,就可以使用bitset快速的在整形,string,二进制三种类型中完成操作转换。并且可以在某些数据结构中直接套用bitset完成二进制的对位操作。还有就是bitset很好用。完XD
STL的容器基本讲的差不多了。熟练掌握STL好处我也就不多说了= = ,自己在做题的过程中慢慢琢磨熟练吧。
STL中bitset的用法的更多相关文章
- STL中mem_fun, mem_fun_ref用法
1.引言 先看一个STL中for_each的用法: #include <iostream> #include <vector> #include <algorithm&g ...
- 位运算 进制转化 STL中bitset用法
2017-08-17 16:27:29 writer:pprp /* 题目名称:输入十进制以二进制显示 程序说明:同上 作者:pprp 备注:无 日期:2017/8/17 */ #include &l ...
- STL中map的用法
map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成有可能在我们处理一对一数据的时候 ...
- (转)STL中set的用法
转载自here 1.关于set map容器是键-值对的集合,好比以人名为键的地址和电话号码.相反地,set容器只是单纯的键的集合.例如,某公司可能定义了一个名为bad_checks的set容器,用于记 ...
- STL中的Set用法(详+转)
set是STL中一种标准关联容器(vector,list,string,deque都是序列容器,而set,multiset,map,multimap是标准关联容器),它底层使用平衡的搜索树——红黑树实 ...
- STL中erase()的用法
erase()是STL提供的容器中比较常用的方法之一,它的功能是删除容器中的某些元素,其中它的函数原型如下: 1.有两个参数,且参数类型都是size_t型: string& erase ( s ...
- STL中nth_element的用法
nth_element函数原型有四个,详细我就不一一累赘了,我们就用最普通的用法寻找第k位置的元素. 函数用法为:nth_element(first,kth,end). first,last 第一个和 ...
- stl中双向队列用法
双向队列的操作如下: d[i]:返回d中下标为I的元素的引用. d.front():返回的一个元素的引用. d.back():返回最后一个元素的引用. d.pop_back():删除尾部的元素.不返回 ...
- STL中set的用法
set,顾名思义,就是数学上的集合——每个元素最多只出现一次,并且set中的元素已经从小到大排好序. 头文件:#include<set> 常用的函数: begin() 返回set容 ...
随机推荐
- Flutter学习笔记(16)--Scaffold脚手架、AppBar组件、BottomNavigationBar组件
如需转载,请注明出处:Flutter学习笔记(15)--MaterialApp应用组件及routes路由详解 今天的内容是Scaffold脚手架.AppBar组件.BottomNavigationBa ...
- Yii CGridView 之 SQL 语句
在CGridView里,有时候需要用到复杂的查询时,可用 CSqlDataProvider替换CActiveDataProvider, CSqlDataProvider 可用复杂的查询语句,例子如下: ...
- Element-UI 2.4.11 版本 使用注意(发现一点更新一点)
1.$Vue.$refs.addForm.resetFields() 的resetFields()方法重置到默认值并不是 ,你在form绑定对象上写的默认值 ,而是这个form被渲染出来之后第一次赋到 ...
- Python3 完美解决unittest框架下不生成测试报告
前提: 1.运行测试用例一切正常,只是没有测试报告显示 2.使用命令行pyhon 脚本名字.py 却可以生成测试报告 3.pycharm 在运行测试用例的时候 默认是以unittest 框架来运行的, ...
- 通过视图实现自定义查询<持续完善中。。。>
目前实现: ----普通查询路径 /viewShow/viewShow/list.htm ----Echarts查询路劲 /viewShow/viewShow/echarts.htm 1.自定义查询条 ...
- unity之初级
- Ajax数据解析格式
Ajax数据解析格式 一.前言 在服务器端 AJAX 是一门与语言无关的技术.在业务逻辑层使用何种服务器端语言都可以. 从服务器端接收数据的时候,那些数据必须以浏览器能够理解的格式来发送.服务器端的编 ...
- Leetcode之二分法专题-367. 有效的完全平方数(Valid Perfect Square)
Leetcode之二分法专题-367. 有效的完全平方数(Valid Perfect Square) 给定一个正整数 num,编写一个函数,如果 num 是一个完全平方数,则返回 True,否则返回 ...
- 【原创】Linux cpufreq framework
背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: Kernel版本: ...
- ResourceManager基本职能和内部架构
YARN也采用了Master/Slave结构,其中,Master实现为ResourceManager,负责整个集群资源的管理与调度:Slave实现为NodeManager,负责单个节点的资源管理与任务 ...