【BZOJ4260】 Codechef REBXOR 可持久化Trie
看到异或就去想前缀和(⊙o⊙)
这个就是正反做一遍最大异或和更新答案
最大异或就是很经典的可持久化Trie,从高到低贪心
WA: val&(1<<(base-1))得到的并不直接是1/0
#include<bits/stdc++.h>
#define ll long long
#define N 400005
using namespace std;
inline int read(){
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=*x+ch-'';ch=getchar();}
return x*f;
}
int n,tot,a[N],rt[N],ch[N*][];
int ans,now,lmx[N],rmx[N];
void build(int &x,int base){
x=++tot;
if(base==-)return;
build(ch[x][],base-);
}
int getmx(int x,int base,int val){
if(!base)return ;
int t=val&(<<(base-));t?t=:t=;
if(ch[x][t]){return (<<(base-))+getmx(ch[x][t],base-,val);}
else return getmx(ch[x][t^],base-,val);
}
void add(int pre,int &x,int base,int val){
x=++tot;
ch[x][]=ch[pre][];ch[x][]=ch[pre][];
if(base==-)return;
int t=val&(<<(base-));t?t=:t=;
add(ch[pre][t],ch[x][t],base-,val);
}
int main(){
n=read();
for(int i=;i<=n;i++)a[i]=read();
now=;tot=;
build(rt[],);
for(int i=;i<=n;i++){
rt[i]=rt[i-];
now^=a[i];
lmx[i]=getmx(rt[i-],,now);
add(rt[i-],rt[i],,now);
}
for(int i=;i<=n;i++)lmx[i]=max(lmx[i],lmx[i-]);
now=;tot=;
memset(ch,,sizeof(ch));
build(rt[],);
for(int i=n;i;i--){
now^=a[i];
rmx[i]=getmx(rt[i+],,now);
add(rt[i+],rt[i],,now);
}
for(int i=n;i;i--)rmx[i]=max(rmx[i],rmx[i+]);
for(int i=;i<n;i++)ans=max(ans,lmx[i]+rmx[i+]);
printf("%d\n",ans);
}
4260: Codechef REBXOR
Time Limit: 10 Sec Memory Limit: 256 MB
Submit: 461 Solved: 206
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1 2 3 1 2
Sample Output
HINT
【BZOJ4260】 Codechef REBXOR 可持久化Trie的更多相关文章
- bzoj 4546: codechef XRQRS [可持久化Trie]
4546: codechef XRQRS 可持久化Trie codechef上过了,bzoj上蜜汁re,看别人说要开5.2e5才行. #include <iostream> #includ ...
- [Bzoj4260]Codechef REBXOR(trie树)
4260: Codechef REBXOR Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1534 Solved: 669[Submit][Stat ...
- BZOJ4260 Codechef REBXOR 题解
题目大意: 有一个长度为n的序列,求1≤l1≤r1<l2≤r2≤n使得(⊕r1i=l1ai)+(⊕r2i=l2ai)最大,输出这个最大值. 思路: 用Trie求出前缀异或和以及后缀异或和,再求出 ...
- [BZOJ4260]Codechef REBXOR(Trie)
Trie模板题.求出每个前缀和后缀的最大异或和区间,枚举断点就可.不知为何跑得飞快. #include<cstdio> #include<cstring> #include&l ...
- BZOJ4260 Codechef REBXOR(trie)
用trie求出前缀最大区间异或和.后缀最大区间异或和即可.注意空间是nlog的. #include<iostream> #include<cstdio> #include< ...
- BZOJ4260: Codechef REBXOR
Description Input 输入数据的第一行包含一个整数N,表示数组中的元素个数. 第二行包含N个整数A1,A2,…,AN. Output 输出一行包含给定表达式可能的最大值. S ...
- BZOJ4260: Codechef REBXOR (01Tire树)
题意 题目链接 Sol 首先维护出前缀xor和后缀xor 对每个位置的元素插入到Trie树里面,每次找到和该前缀xor起来最大的元素 正反各做一遍,取最大. 记得要开log倍空间qwq.. #incl ...
- [BZOJ4260] Codechef REBXOR (01字典树,异或前缀和)
Description Input 输入数据的第一行包含一个整数N,表示数组中的元素个数. 第二行包含N个整数A1,A2,-,AN. Output 输出一行包含给定表达式可能的最大值. Sample ...
- 【BZOJ4260】Codechef REBXOR (Trie树)
[BZOJ4260]Codechef REBXOR (Trie树) 题面 BZOJ 题解 两眼题.第一眼不会做,第二眼好简单... 前缀异或和一下,拿\(Trie\)树维护求一个在这个端点以左的最大值 ...
随机推荐
- SQL索引及视图常用语法
ALTER TABLE department ADD INDEX dept_name_idx (name); SHOW INDEX FROM department \G ALTER TABLE dep ...
- poj 3278:Catch That Cow(简单一维广搜)
Catch That Cow Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 45648 Accepted: 14310 ...
- wp8 入门到精通 生命周期
- 思想&观点&人生
思想: 思想的直接表现往往是对事物的观点,观点越多并且越接近本质,表示思想越丰富和深刻 观点不是事实 观点是基于事实之上的一种系统性的判断和理解框架,事实是观点的基础 观点不一定正确 观点组成: 事实 ...
- iOS中图片动画的三种模式及基本的代码实现
-(void)play { //第一种图片动画模式 头尾方式 //头尾方式 [UIView beginAnimations:nil context:nil];//动画开始 [UIView setAni ...
- jfreeChart柱状图各属性详细设置
一. 下载与环境配置 此最新版本为 1.0.13 解压jfreechart-1.0.13.zip 将lib目录下的jfreechart-1.0.13.jar .jcommon-1.0.16.jar 复 ...
- 【T_SQL】 基础 续+++
十五.T-SQL 编程 1.变量 (1)局部变量 A.局部变量必须以标记@作为前缀 ,如@age. B.局部变量的使用也是先 ...
- cdh环境下,spark streaming与flume的集成问题总结
文章发自:http://www.cnblogs.com/hark0623/p/4170156.html 转发请注明 如何做集成,其实特别简单,网上其实就是教程. http://blog.csdn.n ...
- 关于Vector中的元素中含有指针成员的情况
对于容器,当容器的各个元素为类类型,且该类类型中含有指针成员时: 如果类类型的析构函数中包含了对指针变量指向内存的释放操作,则在利用clear()函数删除容器所有元素时,会自动调用类的析构函数,自动实 ...
- Liferay 6.2 改造系列之十二:修改Portal设置页面表单内容
将Portal设置页面中无用的内容删除: 在/portal-master/portal-impl/src/portal.properties文件中,有如下配置: # # Input a list of ...