我是蒟蒻一名,请大佬勿喷。

绝大部分来自https://www.cnblogs.com/magisk/p/8809922.html   ,  可以去大佬博客逛一逛

bitset是C++中类似数组的一种结构,但是因为每位只能是0或1,对于某些明显的二进制题目来说,如果你不会压位的话,bitsei确实为一个很好的选择。

bitset有4个构造函数。

 #include <iostream>
#include<bitset>
using namespace std;
int main()
{
bitset<> a("");//此处不能出现除了0 1之外的字符,否则将会抛出异常
bitset<> b();//二进制
bitset<> c;//无参构造函数,初始化为0
bitset<> d(a);//拷贝构造函数
cout<<a<<endl;
cout<<b<<endl;
cout<<c<<endl;
cout<<d<<endl;
//使用bitset解题时,注意他如果要输出最后二进制答案,一定要反过来
return ;
}

若bitset位数大于操作数,前面用零补充

bitset中有的操作符

 #include <iostream>
#include<bitset>
using namespace std;
int main()
{
bitset<> a("");//此处不能出现除了0 1之外的字符,否则将会抛出异常
bitset<> b();//二进制
bitset<> c;//无参构造函数,初始化为0
bitset<> d(a);//拷贝构造函数 cout<<(a&b)<<endl;//按位与,整型数也是二进制存在计算机里面的,bitset当然也可以
//意思就是整型有的位运算,bitset全都有
//不过要记住的是要打括号
cout<<(a|b)<<endl;
cout<<(a^b)<<endl;
cout<<(a>>)<<endl;
cout<<(a<<)<<endl;
//前面说bitset类似于数组,那么肯定可以通过下标访问元素的
a[]=;
cout<<a<<endl;//结果为0000000011
//还是那个注意点,反的
//结合int的值就很好理解了
return ;
}

如果题目要求输出不带前导零的二进制答案,那么

#include <iostream>
#include<bitset>
using namespace std;
int main()
{
bitset<10> a("10");//此处不能出现除了0 1之外的字符,否则将会抛出异常
int w=-1;
for(int i=a.size();i>=0;i--)
{
if(a[i])
{
w=i;
break;
}
}
for(int i=w;i>=0;i--)
{
cout<<a[i];
}
return 0;
}

  虽然下面会讲bitset的函数可以完成同样的功能,但是蒟蒻的我觉得应该效率和循环应该差不太多

bitset中的函数

 #include <iostream>
#include<bitset>
using namespace std;
int main()
{
bitset<> a("");
cout<<a.count()<<endl;//返回bitset中1的个数
cout<<a.test()<<endl;//相当于数组式的访问,但是会有下标检查
cout<<a.size()<<endl;//返回大小,是最开始定义的大小
cout<<a.any()<<endl;//返回bitset中是否有1
cout<<a.none()<<endl;//返回bitset中是否没有1
cout<<a.all()<<endl;//返回是否全为1 bitset<> b("");
cout<<b.flip()<<endl;//取反,若给参数,则将参数位取反
cout<<b.set()<<endl;//置1
cout<<b.reset()<<endl;//清0
//以上全都可带参数,大概同flip
cout<<b.set(,)<<endl;//相当于b[2]=1; bitset<> c("");
string t1=c.to_string();
unsigned t2=c.to_ulong();
unsigned long long t3=c.to_ullong();
cout<<t1<<endl;//
cout<<t2<<endl;//
cout<<t3<<endl;//
return ;
}

差点忘了贴实例

链接:https://ac.nowcoder.com/acm/contest/1114/C
来源:牛客网
有n个长度为m的文本串,每个串只含有'0'和'1'。接下来有Q次询问,每次给出一个长度为m的字符串,且只含有'0','1'和'_'。如10_1_1。下划线可以匹配'0'或'1'。即10_1_1可以匹配101111,101101,100111,100101四种串。每次询问求出n个文本串中有多少个可以与当前询问的串匹配。

1<=n,m<=1000,1<=q<=100

 #include <iostream>
#define ll long long
#include<bitset>
using namespace std;
bitset<> bit[];
int main()
{
int n,m;
cin>>n>>m;
for(int i=;i<n;i++)
{
for(int j=;j<m;j++)
{
char t;
cin>>t;
bit[i][j]=( t=='' );
}
}
int q;
cin>>q;
while(q--)
{
int ans=;
bitset<> t1,t2,t3,t4;
for(int i=;i<m;i++)
{
char tmp;
cin>>tmp;
t1[i]=tmp==''?:;
t2[i]=tmp==''?:;
}
for(int i=;i<n;i++)
{
t3=t1&bit[i];
t4=t2&bit[i];
if((t3==t1)&&t4.count()==)
ans++;
}
cout<<ans<<endl;
}
return ;
}

代码有点丑,希望别介意(介意我也没办法)

观察题目之后发现m*n=1e6

所以如果可以直接判断文本串是否与询问匹配就可以了

t1存储询问串中所有的1

t2存储询问串中所有的0

因为1&0=0

所以将询问串中等于0的位置在t2中置1,如果t2&文本串==0则0对应起来的,否则不对应

bitset归结,一个实例的更多相关文章

  1. C#[Win32&WinCE&WM]应用程序只能运行一个实例:MutexHelper

    前言 在开发应用程序时,通常只让程序运行一个实例.所以,就要判断程序是否已经运行. 下面是我自己在项目中使用到,封装好的帮助类.有 普通的 C# 应用程序 和 Windows CE 和 Windows ...

  2. 转 C# 只允许运行一个实例

    来源:http://blog.csdn.net/jin20000/article/details/3136791 互斥进程(程序), 简单点说,就是在系统中只能有该程序的一个实例运行. 现在很多软件都 ...

  3. C# 只启动一个实例完全解决方案

    工作上经常会遇到"程序只能启动一个实例"这样的需求. 我想,这样的需求应该很普遍,所以没打算去动脑筋,去找谷歌问下就得了,用下来发现,不是这里不爽就是那里不行. 先说下我详细的几点 ...

  4. ArcGIS API for JavaScript开发环境搭建及第一个实例demo

    原文:ArcGIS API for JavaScript开发环境搭建及第一个实例demo ESRI公司截止到目前已经发布了最新的ArcGIS Server for JavaScript API v3. ...

  5. Sqlserver Sql Agent Job 只能同时有一个实例运行

    Sqlserver Sql Agent中的Job默认情况下只能有一个实例在运行,也就是说假如你的Sql Agent里面有一个正在运行的Job叫"Test Job",如果你现在再去启 ...

  6. c# 只允许一个实例运行

    1.单件模式,Singleton,应用程序只能允许一个实例在运行.这是最好的解决方法2.查询系统进程里是不是已经运行.private void Form1_Load(object sender, Ev ...

  7. Python使用MySQL数据库的方法以及一个实例

    使用环境:Windows+python3.4+MySQL5.5+Navicat 一.创建连接 1.准备工作,想要使用Python操作MySQL,首先需要安装MySQL-Python的包,在Python ...

  8. Linux编程之《只运行一个实例》

    概述 有些时候,我们要求一个程序在系统中只能启动一个实例.比如,Windows自带的播放软件Windows Medea Player在Windows里就只能启动一个实例.原因很简单,如果同时启动几个实 ...

  9. Qt之运行一个实例进程

    简述 发布程序的时候,我们往往会遇到这种情况: 只需要用户运行一个实例进程 用户可以同时运行多个实例进程 一个实例进程的软件有很多,例如:360.酷狗- 多个实例进程的软件也很多,例如:Visual ...

  10. winform托盘时,要运行一个实例,解决办法

    需求:winform应用程序,当隐藏到托盘时,再次运行exe程序,让其只运行一个实例,并且把窗口从托盘中显示出来 应用程序名可以通过下面代码,获取到: Process current = Proces ...

随机推荐

  1. 进程池和multiprocess.Pool模块

    一.为什么要有进程池 首先,创建进程需要消耗时间,销毁进程也需要时间.其次,即使开启了成千上万的进程,操作系统也不能让它们同时执行,这样反而会影响程序的效率.因此我们不能无限制的根据任务开启或者结束进 ...

  2. 最长公共上升子序列 (LIS+LCS+记录)

    [题目描述] 给出两个序列,求出最长公共上升子序列的长度,并输出其中一个解. [题目链接] http://noi.openjudge.cn/ch0206/2000/ [算法] 经典问题,结合了LIS和 ...

  3. C# form 传参数的几个方法

    方法一:传值最先想到的,Form2构造函数中接收一个string类型参数,即Form1中选中行的文本,将Form2的TextBox控件的Text设置为该string,即完成了Form1向Form2的传 ...

  4. wait()和sleep()、sleep()和yield()的区别

    wait()和sleep()的区别主要表现在一下几个方面: 原理不同.sleep()方法是Thread类的静态方法,是线程用来控制自身流程的.它会使线程暂停执行一段时间,把执行机会让给其他线程,等到时 ...

  5. CS184.1X 计算机图形学导论(第五讲)

    一.观察:正交投影 1.特性:保持平行线在投影后仍然是平行的 2.一个长方体,对处在只有深度不同的位置上的同一物体来说,它的大小不会改变. 3.透视投影:平行线在远处会相交(例如铁轨) 4.glOrt ...

  6. PHP: 双层 for循环的执行过程

    先看代码 <?php for ($i = 0; $i<3; $i++) { for ($x = 0; $x<3; $x++) { // code... } } ?> 看下它的执 ...

  7. 解决IDEA项目名称无下标蓝色小方块

    点击下图中 + 号,引入该工程的pom.xml即可 .

  8. Python3.5-20190502-廖老师-自我笔记

    python的语法主要就是严格的缩进.一般缩进都是四个空格.以冒号结尾的(:)就意味着他后面有代码块.(js代码块使用{}抱起来的,我记得c语言也是,但是python就不需要,他只要严格缩进的就可以了 ...

  9. Java二级练习试题一

    为保护本地主机,对Applet安全限制中正确的是() A. Applet可加载本地库或方法 B. Applet可读.写本地计算机的文件系统 C. Applet可向Applet之外的任何主机建立网络连接 ...

  10. shiro 安全框架 详解

    ---恢复内容开始--- Shiro 简介 简介• Apache Shiro 是 Java 的一个安全(权限)框架.• Shiro 可以非常容易的开发出足够好的应用,其不仅可以用在JavaSE 环境, ...