[CC-MINXOR]XOR Minimization

题目大意:

有一个长度为\(n\)的数列\(A_{1\sim n}\)。\(q\)次操作,操作包含以下两种:

  • 询问\(A_{l\sim r}\)中最小值及其出现次数;
  • 将\(A_{l\sim r}\)中每个数字异或上\(k\)。

\(n\le250,000;q\le50,000;0\le A_i,k<2^{16}\)

思路:

分块+字典树

源代码:

#include<cmath>
#include<cstdio>
#include<cctype>
#include<cstring>
#include<algorithm>
inline int getint() {
register char ch;
while(!isdigit(ch=getchar()));
register int x=ch^'0';
while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
return x;
}
const int N=250000,B=500,K=1<<16;
int n,a[N],tag[B],bel[N],beg[B],end[B];
struct Node {
int val,cnt;
};
class Trie {
private:
int val[K<<1];
public:
void reset() {
memset(val,0,sizeof val);
}
void insert(const int &x) {
for(register int i=15,p=1;i>=0;i--) {
p=p<<1|((x>>i)&1);
val[p]++;
}
}
Node query(const int &x) const {
int p=1,ret=0;
for(register int i=15;i>=0;i--) {
p<<=1;
if(val[p|((x>>i)&1)]) {
p|=(x>>i)&1;
} else {
ret|=1<<i;
p|=((x>>i)&1)^1;
}
}
return (Node){ret,val[p]};
}
};
Trie t[B];
inline void rebuild(const int &k) {
t[k].reset();
for(register int i=beg[k];i<=end[k];i++) {
t[k].insert(a[i]);
}
}
inline void modify(const int &l,const int &r,const int &k) {
if(bel[l]==bel[r]) {
for(register int i=beg[bel[l]];i<=end[bel[l]];i++) {
a[i]^=tag[bel[l]];
}
tag[bel[l]]=0;
for(register int i=l;i<=r;i++) {
a[i]^=k;
}
rebuild(bel[l]);
return;
}
for(register int i=beg[bel[l]];i<=end[bel[l]];i++) {
a[i]^=tag[bel[l]];
}
tag[bel[l]]=0;
for(register int i=l;i<=end[bel[l]];i++) {
a[i]^=k;
}
rebuild(bel[l]);
for(register int i=bel[l]+1;i<bel[r];i++) {
tag[i]^=k;
}
for(register int i=beg[bel[r]];i<=end[bel[r]];i++) {
a[i]^=tag[bel[r]];
}
tag[bel[r]]=0;
for(register int i=beg[bel[r]];i<=r;i++) {
a[i]^=k;
}
rebuild(bel[r]);
}
inline Node query(const int &l,const int &r) {
Node ans=(Node){K,0};
if(bel[l]==bel[r]) {
for(register int i=l;i<=r;i++) {
if((a[i]^tag[bel[i]])<ans.val) {
ans=(Node){a[i]^tag[bel[i]],0};
}
if((a[i]^tag[bel[i]])==ans.val) {
ans.cnt++;
}
}
return ans;
}
for(register int i=l;i<=end[bel[l]];i++) {
if((a[i]^tag[bel[i]])<ans.val) {
ans=(Node){a[i]^tag[bel[i]],0};
}
if((a[i]^tag[bel[i]])==ans.val) {
ans.cnt++;
}
}
for(register int i=bel[l]+1;i<bel[r];i++) {
const Node tmp=t[i].query(tag[i]);
if(tmp.val<ans.val) {
ans=(Node){tmp.val,0};
}
if(tmp.val==ans.val) {
ans.cnt+=tmp.cnt;
}
}
for(register int i=beg[bel[r]];i<=r;i++) {
if((a[i]^tag[bel[i]])<ans.val) {
ans=(Node){a[i]^tag[bel[i]],0};
}
if((a[i]^tag[bel[i]])==ans.val) {
ans.cnt++;
}
}
return ans;
}
int main() {
n=getint();
const int q=getint(),block=sqrt(n);
for(register int i=0;i<n;i++) {
bel[i]=i/block;
a[i]=getint();
t[bel[i]].insert(a[i]);
if(i&&bel[i]!=bel[i-1]) {
beg[bel[i]]=i;
}
end[bel[i]]=i;
}
for(register int i=0;i<q;i++) {
const int opt=getint(),l=getint()-1,r=getint()-1;
if(opt==1) {
const Node ans=query(l,r);
printf("%d %d\n",ans.val,ans.cnt);
}
if(opt==2) {
modify(l,r,getint());
}
}
return 0;
}

最新文章

  1. DELL灵越15R5521安装黑苹果
  2. 移动web点5像素的秘密
  3. C#动态编译代码,执行一个代码片段,或者从指定文件中加载某个接口的实现类
  4. js中实现中文按字母拼音排序
  5. IOS第17天(1,Quartz2D图片水印)
  6. FUNCS.H中的函数声明
  7. Metro之Popup控件的使用(登录)
  8. Google Guava学习笔记——基础工具类针对Object类的使用
  9. 【多线程】JAVA多线程和并发基础面试问答(转载)
  10. android中给TextView或者Button的文字添加阴影效果
  11. 在ADS上由于volatile惹得祸
  12. IDEA 下新建 Hibernate 项目
  13. python-基于tcp协议的套接字(加强版)及粘包问题
  14. 逆天的 GRUB
  15. 011_如何decode url及图片转为base64文本编码总结
  16. 【整理】HTML5游戏开发学习笔记(1)- 骰子游戏
  17. linux程序调试命令addr2line之入门简单介绍(本文先不聊gdb调试)
  18. Python装饰器(Decorator)简介
  19. React Native 搭建开发环境
  20. js 获取html5的data属性

热门文章

  1. swagger2常用注解说明
  2. Appium Python API 中文版
  3. 如何录制Chrome或者Linux下的应用
  4. 饮冰三年-人工智能-linux-03 Linux文件管理(权限管理+归档+压缩)
  5. Python语音识别(计算器)
  6. 牛客寒假算法基础集训营4 I题 Applese 的回文串
  7. 51 Nod 1256 乘法逆元(数论:拓展欧几里得)
  8. 20165323 结对编程之四则运算week2-整体总结
  9. PHP Fatal error: SOAP-ERROR: Parsing WSDL: Couldn&#39;t load from &#39;http://xxxx.wsdl&#39;
  10. Python_collections_Counter计数器部分功能介绍