【某集训题解】【DAY 2 T3】与非
题目描述
作为一名新世纪共产主义的接班人,你认识到了资本主义的软弱性与妥协性,决定全面根除资本主义,跑步迈入共产主义。但是当你即将跨入共产主义大门的时候,遇到了万恶的资本家留下的与非电路封印,经过千辛万苦的研究,你终于把复杂的破解转变成了以下问题:
初始时你有一个空序列,之后有N个操作。
操作分为一下两种:
1 x:在序列末尾插入一个元素x(x=0或1)。
2 L R:定义nand[L,R]为序列第L个元素到第R个元素的与非和,询问nand[L,L]^nand[L,L+1]^nand[L,L+2]^......^nand[L,R]。
Nand就是先与,再取反
输入
从文件nand.in中读入数据。
输入第一行一个正整数N,表示操作个数。
接下来N行表示N个操作。
为了体现程序的在线性,记lastans为上一次操作二的回答,初始lastans=0,。对于操作1,你需要对x异或lastans。对于操作二,设现在序列中的元素个数为M,如果lastans=1,那么你需要作如下操作:L=M-L+1,R=M-R+1,swap(L,R)
输出
输出到nand.out中。
输出有多行。为对于每一个操作二的回答。
样例输入
6
1 1
1 1
1 0
2 1 2
2 1 3
2 2 3
样例输出
1
0
0
提示
【数据规模和约定】
数据点 N的规模 操作一的个数M1 操作二的个数M2
1 N<=1000 M1<=500 M2<=500
2 N<=1000 M1<=500 M2<=500
3 N<=200000 M1<=100000 M2<=100000
4 N<=200000 M1<=100000 M2<=100000
5 N<=1000000 M1<=900000 M2<=100000
题解:
据说正解是什么线段树(?)反正我跑得快233。
其实不是很难,推一下式子就好了。
Nand[ i ,j ]定义同题面。那么nand[i,j]=!(nand[ I , j-1 ]&a[ j ]) =。。。(!a[ I ]& a [ i+1])&…….
F[ I ]表示nand[ 1,I ]。F[ j ]= ……!((! F[i-1]&a [i ])&a[ i+1 ])……Sum[ i] =f[1]^…^f[I ]观察上下两式。F[j]与nand[ I ,J ]结果与!(a[ I ]& a [ i+1])和!((! F[i-1]&a [i ])&a[ i+1 ]))有关。分类讨论一下,当A[I+1 ]==0时,两式结果相等,当A[I+1 ]==1时,那么仅在(A[ I ]==1&&F[I-1]==1)||(A[I]==0)时对答案可能产生影响。前者使这一层变成0与1,后者使这一层变成1与0 。
(具体不太好写,我在下面写一下式子)
当A[ I ]==1&&F[I-1]==1/(A[I]==0时可以自己画一下)
|
假设到A[I+X]之前A[I+?]都是1 |
&A[I+1] 然后! |
&A[I+2] |
&A[I+3] |
&A[I+4] |
&A[I+5] |
… |
&A[I+X] |
|
a[ I ] |
0 |
1 |
0 |
1 |
0 |
… |
1 |
|
! F[i-1]&a [i ] |
1 |
0 |
1 |
0 |
1 |
… |
1 |
这也就意味着在F[I+X]之前F[I+y]与nand[I,I+Y]一直是相反的,所以他们的区间异或和仅与X的奇偶性有关(大家可以自己推一下)。从I+X到R,F数组的结果一直与nand[I,I+X+…]相等,这也就意味着这之后的F异或和与nand相等,所以这部分我们可以用F数组的答案来代替nand。再考虑前面F与nand不相等的部分。已经说过这部分异或和仅与X的奇偶性有关。
最终答案就是sum[R]^sum[L-1]^1(x为奇数)sum[R]^sum[L-1](x为偶数)。对于查单点要特判233。
代码:
#include<cstdio>
#include<iostream>
using namespace std;
const int N=;
inline int read(){
int s=,k=;char ch=getchar();
while(ch<''||ch>'') k=ch=='-'?-:k,ch=getchar();
while(ch>=''&&ch<='') s=s*+(ch^),ch=getchar();
return s*k;
}
int n,m;
bool ans;
bool f[N],a[N];
bool sum[N];
int main(){
n=read();
for(int i=,op,x,l,r;i<=n;i++){
op=read();
if(op==){
x=read()^ans;
m++;
a[m]=x;
if(m==) f[m]=x;
else f[m]=-(f[m-]&x);
sum[m]=sum[m-]^f[m];
}
else{
l=read(),r=read();
if(ans==){
l=m-l+,r=m-r+; swap(l,r);
}
ans=a[l];
int j=l;
bool s=-(a[l]&a[l+]);
while(s!=f[j+]&&j<r){
ans^=s;
j++;
s=-(s&a[j+]);
}
if(j<r){
ans^=sum[r]^sum[j];
}
printf("%d\n",ans);
}
}
}
【注】:其实在查询【L,R】第一个0出现位置应用二分查或者链表,但题目数据太水,就直接暴力咯。
链表版(不是自己打的,懒,而且实测居然比暴力慢233):
#include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdio>
#include <cmath>
using namespace std;
const int M=+;
int n,ans,cnt,p;
int pre[M],nxt[M],sum[M],f[M],val[M];
inline int read(){
int x=,f=;char ch=getchar();
while(ch<''||ch>'') {if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<='') {x=(x<<)+(x<<)+(ch^);ch=getchar();}
return x*f;
}
int main(){
n=read();
for(int i=;i<=n;i++){
int opt,l,r;
opt=read();
if(opt==){
//cout<<opt<<endl;
val[++cnt]=read();
val[cnt]^=ans;
if(!val[cnt]){
nxt[p]=cnt;
p=cnt;
}else pre[cnt]=p;
if(cnt==)
f[]=sum[]=val[cnt];
else{
f[cnt]=!(f[cnt-]&val[cnt]);
sum[cnt]=sum[cnt-]^f[cnt];
}
}else{
//cout<<opt<<endl;
l=read();r=read();
if(ans==){
l=cnt-l+;r=cnt-r+;
swap(l,r);
}
if(l==r) { printf("%d\n",ans=val[l]);continue;}
if(val[l]==f[l]) {printf("%d\n",ans=sum[r]^sum[l-]);continue;}
else{
int pos=nxt[pre[l]];
if(val[l]==) pos=nxt[l];
pos=min(pos,r+);
int pd=pos-l;
if(pd&) {printf("%d\n",ans=sum[r]^sum[l-]^);continue;}
else {printf("%d\n",ans=sum[r]^sum[l-]);continue;}
}
//printf("%d\n",sum[r]^sum[l-1]);continue;
}
}
// while(1);
return ;
}
【某集训题解】【DAY 2 T3】与非的更多相关文章
- 2021-06-27 & 2021-06-28 集训题解
西克 题目传送门 Description Solution 跟 2021年省选A卷D2T1 一模一样,懒得讲了 不过这个题似乎有点卡空间,所以卡不过去 Code #include <bits/s ...
- 十二省联考题解 - JLOI2019 题解
十二省联考题解 - JLOI2019 题解 两个T3的难度较大 平均代码量远大于去年省选 套路题考查居多 A 难度等级 1 $n^2$暴力可以拿到$60$分的优秀成绩 然后可以想到把区间异或转化为前缀 ...
- 牛客网NOIP赛前集训营-提高组(第一场)
牛客的这场比赛感觉真心不错!! 打得还是很过瘾的.水平也比较适合. T1:中位数: 题目描述 小N得到了一个非常神奇的序列A.这个序列长度为N,下标从1开始.A的一个子区间对应一个序列,可以由数对[l ...
- 【题解】[Ghd]
[题解]Ghd 一道概率非酋题? 题目很有意思,要我们选出大于\(\frac{n}{2}\)个数字使得他们的最大公约数最大. 那么我们若随便选择一个数字,他在答案的集合里的概率就大于\(0.5\)了. ...
- BZOJ2453: 维护队列
2453: 维护队列 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 183 Solved: 89[Submit][Status] Descripti ...
- Redis持久存储-AOF&RDB
Redis中数据存储模式有2种:cache-only,persistence;cache-only即只做为"缓存"服务,不持久数据,数据在服务终止后将消失,此模式下也将不存在&qu ...
- [NOI赛前训练]——专项测试3·数学
由于并不想写T1和T2的题解……所有只有T3的题解了. T3 由于内部题就只写题解了. 好吧,我是一点都不想写…… 说一下这zz题解哪里写错了吧…… ……不想写…… 就说一个吧…… $n-\frac{ ...
- NOI导刊 2018河南郑州游记
前言 本蒟蒻来自浙江的弱市弱校,因为不想两年\(OI\)一场空,以及想出去玩,所以与同届大佬一起报了\(NOI\)导刊,希望能留下点不错的记忆吧. \(Day\ 0\) \(10\)月\(1\)日 经 ...
- 我是怎么从安卓到php再成为前端开发工程师的
记得我下定决心学Android(安卓)是17年的暑假,暑假前,学校组织了一次集训,美其名曰帮我们巩固知识,实际上就是学校和长沙的培训学校某牛达成了合作,教我们一些基础知识,然后集训完建议那些在学校没学 ...
随机推荐
- golang 私钥"加密"公钥"解密"
---恢复内容开始--- 之前工作主要使用C/C++与银行/第三方支付对接,但C/C++无法满足客户"当天给协议明天实盘上载"的开发速度以及现公司一些特殊情况,所以决定用go来 ...
- 如何用VMware打开vmdk文件
vmdk文件是一个虚拟机备份文件!你可以在vmware新建一个任何类型的虚拟机,命名为“test”,在“我的文档”找到vmware的虚拟机目录“test”,在"test"目录中可以 ...
- C++ inline函数与编译器设置
1. 经过测试#define与inline的速度几乎没有区别. 2. inline函数更为安全,有效避免了#define二义性问题.inline是真正的函数,而#define只是在字符串意义上的宏替换 ...
- Spring 学习一
Spring工作机制及为什么要用? 1.springmvc将所有的请求都提交给DispacherServlet,他会委托应用系统的其他模块负责对请求进行真正的处理工作. 2.DispacherServ ...
- (转载)Oracle10g 数据泵导出命令 expdp 使用总结(一)
原文链接:http://hi.baidu.com/edeed/item/890626ef6f6d9d265b2d646f Oracle10g 数据泵导出命令 expdp 使用总结(二)Oracle10 ...
- poj 1948 Triangular Pastures 小结
Description Like everyone, cows enjoy variety. Their current fancy is new shapes for pastures. The o ...
- 谈谈关于PHP的代码安全相关的一些致命知识
谈谈关于PHP的代码安全相关的一些致命知识 目标 本教程讲解如何防御最常见的安全威胁:SQL 注入.操纵 GET 和 POST 变量.缓冲区溢出攻击.跨站点脚本攻击.浏览器内的数据操纵和远程表单提交. ...
- Struts2请求参数合法性校验机制
在Action中通过代码执行数据校验 请求参数的输入校验途径一般分两种:客户端校验 :通过JavaScript 完成 (jquery validation插件),目的:过滤正常用户的误操作. 服务器校 ...
- POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 【USACO】距离咨询(最近公共祖先)
POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 [USACO]距离咨询(最近公共祖先) Description F ...
- CJOJ 1070 【Uva】嵌套矩形(动态规划 图论)
CJOJ 1070 [Uva]嵌套矩形(动态规划 图论) Description 有 n 个矩形,每个矩形可以用两个整数 a, b 描述,表示它的长和宽.矩形 X(a, b) 可以嵌套在矩形 Y(c, ...