[ABC261E] Many Operations
Problem Statement
We have a variable \(X\) and \(N\) kinds of operations that change the value of \(X\). Operation \(i\) is represented as a pair of integers \((T_i,A_i)\), and is the following operation:
- if \(T_i=1\), it replaces the value of \(X\) with \(X\) and \(A_i\);
- if \(T_i=2\), it replaces the value of \(X\) with \(X\) or \(A_i\);
- if \(T_i=3\),, it replaces the value of X with X xor \(A_i\).
Initialize \(X\) with the value of \(C\) and execute the following procedures in order:
- Perform Operation 1, and then print the resulting value of \(X\).
- Next, perform Operation 1,2 in this order, and then print the value of \(X\).
- next, perform Operation 1,2,3 in this order, and then print the value of X.
 ⋮
- Next, perform Operation 1,2,…,N in this order, and then print the value of X.
Constraints
- \(1≤N≤2×10^5\)
- \(1≤T_i≤3\)
- \(0≤A_i<2^{30}\)
- \(0≤C<2^{30}\)
- All values in input are integers.
Input
Input is given from Standard Input in the following format:
\(N\) \(C\)
\(T_1\) \(A_1\)
\(T_2\) \(A_2\)
⋮
\(T_N\) \(A_N\)
Output
Print \(N\) lines, as specified in the Problem Statement.
Sample Input 1
3 10
3 3
2 5
1 12
Sample Output 1
9
15
12
The initial value of \(X\) is \(10\).
- Operation \(1\) changes \(X\) to \(9\).
- Next, Operation \(1\) changes \(X\) to \(10\), and then Operation \(2\) changes it to \(15\).
- Next, Operation \(1\) changes X to \(12\), and then Operation \(2\) changes it to \(13\), and then Operation \(3\) changes it to \(12\).
Sample Input 2
9 12
1 1
2 2
3 3
1 4
2 5
3 6
1 7
2 8
3 9
Sample Output 2
0
2
1
0
5
3
3
11
2
为了方便,称执行操作1,2\(\cdots\)为第i轮操作
位运算问题,考虑按位计算。把C拆成每一位,求出他的运算后的答案。这是就只用考虑and,xor,or 0/1
- xor 0,and 1,or 0可以看作不变,不操作 
- xor 1其实就是取反,可以打上取反标记。 
- and 0=直接赋值为0,取反标记清空,答案直接为0,不管前面有哪些多少操作。 
- or 1=直接赋值为1,同上 
但是有很多轮操作,所以我们可以推出第i轮结束时赋值和取反操作情况。如果是没有赋值,那么第i轮结束后这一位答案就是上一轮结束答案^取反操作,否则就直接赋值。注意取反后赋值操作跟着取反。
每一位都这样操作,相加,就求出了答案。
#include<cstdio>
const int N=2e5+5;
int n,c,ans[N],rt,tx,tt,t[N],a[N];
int main()
{
	scanf("%d%d",&n,&c);
	for(int i=1;i<=n;i++)
		scanf("%d%d",t+i,a+i);
	for(int i=30;~i;i--)
	{
		tx=0,rt=-1,tt=c>>i&1;//rt:赋值,tx:取反
		for(int j=1;j<=n;j++)
		{
			if(t[j]==1)
				if(!(a[j]&1<<i))
					rt=tx=0;
			if(t[j]==2)
				if(a[j]&1<<i)
					rt=1,tx=0;
			if(t[j]==3)
				if(a[j]&1<<i)
					tx^=1;
			if(rt==-1)
				tt=tt^tx;
			else
				tt=rt^tx;
			ans[j]+=tt<<i;
		}
	}
	for(int i=1;i<=n;i++)
		printf("%d\n",ans[i]);
}
[ABC261E] Many Operations的更多相关文章
- backup, file manipulation operations (such as ALTER DATABASE ADD FILE) and encryption changes on a database must be serialized.
		昨天在检查YourSQLDba备份时,发现有台数据库做备份时出现了下面错误信息,如下所示: <Exec> <ctx>yMaint.ShrinkLog</ctx> ... 
- HDU 5938 Four Operations(四则运算)
		p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ... 
- ios基础篇(二十九)—— 多线程(Thread、Cocoa operations和GCD)
		一.进程与线程 1.进程 进程是指在系统中正在运行的一个应用程序,每个进程之间是独立的,每个进程均运行在其专用且受保护的内存空间内: 如果我们把CPU比作一个工厂,那么进程就好比工厂的车间,一个工厂有 ... 
- OpenCascade Modeling Algorithms Boolean Operations
		Modeling Algorithms Boolean Operations of Opencascade eryar@163.com 布尔操作(Boolean Operations)是通过两个形状( ... 
- A.Kaw矩阵代数初步学习笔记 4. Unary Matrix Operations
		“矩阵代数初步”(Introduction to MATRIX ALGEBRA)课程由Prof. A.K.Kaw(University of South Florida)设计并讲授. PDF格式学习笔 ... 
- A.Kaw矩阵代数初步学习笔记 3. Binary Matrix Operations
		“矩阵代数初步”(Introduction to MATRIX ALGEBRA)课程由Prof. A.K.Kaw(University of South Florida)设计并讲授. PDF格式学习笔 ... 
- mouse scrollings and  zooming operations in linux & windows are opposite
		mouse scrollings and zooming operations in linux & windows are opposite. windows中, 鼠标滚动的方向是: 查看页 ... 
- MongoDB—— 写操作 Core MongoDB Operations (CRUD)
		MongoDB使用BSON文件存储在collection中,本文主要介绍MongoDB中的写操作和优化策略. 主要有三种写操作: Create Update ... 
- MongoDB—— 读操作 Core MongoDB Operations (CRUD)
		本文主要介绍内容:从MongoDB中请求数据的不同的方法 Note:All of the examples in this document use the mongo shell interface ... 
- [codeforces 339]D. Xenia and Bit Operations
		[codeforces 339]D. Xenia and Bit Operations 试题描述 Xenia the beginner programmer has a sequence a, con ... 
随机推荐
- arthas的安装及使用
			arthas的安装及使用 官方文档 安装 #1.下载 https://arthas.aliyun.com/download/latest_version?mirror=aliyun #2.将下载文件上 ... 
- 【Hexo】插件推荐以及使用小技巧
			目录 插件推荐 hexo-deployer-git hexo-word-counter hexo-abbrlink hexo-generator-sitemap 小技巧 自定义提交信息 参考资料 He ... 
- ATtiny88初体验(五):ADC
			ATtiny88初体验(五):ADC ADC模块介绍 ATtiny88单片机包含一个10bit分辨率的ADC模块,拥有8个通道,最大采样率15kSPS,转换时间14us.ATtiny88的ADC参考电 ... 
- 记一次weak_up函数绕过
			2023 蓝帽杯CTF LovePHP 因为比赛已经结束,所以复现环境是从本地进行复现,这次比赛本来排名挺靠前的,原本总排名是60多名,赛区排名30多名,本来是以为有希望进入半决赛的,但是没想到比赛结 ... 
- Python 基础面试第四弹
			1. Python中常用的库有哪些,作用分别是什么 requests: requests 是一个用于发送 HTTP 请求的库,它提供了简单而优雅的 API,可以轻松地发送 GET.POST.PUT.D ... 
- 现代 CSS 解决方案:数学函数 Round
			在 CSS 中,存在许多数学函数,这些函数能够通过简单的计算操作来生成某些属性值,例如在现代 CSS 解决方案:CSS 数学函数一文中,我们详细介绍了 calc():用于计算任意长度.百分比或数值型数 ... 
- VR国标
			<软件基本要求与测试方法> 
- jQuery下拉框级联实现
			参考代码: //企业类别级联 function getCatalog(){ var name=document.getElementById("Lcata").value; var ... 
- [初学C#] 第二习题 : 快递跟踪信息查询
			刚学C#, 折腾的一个小玩意. 熟悉和了解C#这门编程语言. 没有啥特殊意义 解锁技能 - System.Net 的 WebRequest等http请求 - Newtonsoft.Json 这个第三方 ... 
- Python正则表达式——常用re正则表达式集合
			文章目录 一.校验数字的表达式 二.校验字符的表达式 三.特殊需求表达式 一.校验数字的表达式 数字:^[0-9]*$ n位的数字:^\d{n}$ 至少n位的数字:^\d{n,}$ m-n位的数字:^ ... 
