「LOJ#10051」「一本通 2.3 例 3」Nikitosh 和异或(Trie
2024-08-28 16:47:28
题目描述
原题来自:CODECHEF September Challenge 2015 REBXOR
1≤r1<l2≤r2≤N,x⨁yx\bigoplus yx⨁y 表示 xxx 和 yyy 的按位异或。
输入格式
输出格式
输出一行包含给定表达式可能的最大值。
样例
数据范围与提示
5,0≤Ai≤109。
题解
首先记录异或前缀和$s[i]=a[1]⊕a[2]⊕a[3] ...⊕a[i]$。
设$l[i]$为以$i$结尾的区间中,异或值的最大值。
因为异或有 $x⊕x=0$ 的性质,所以区间 $[l,r]$ 的异或值
$=a[l]⊕a[l+1]⊕...⊕a[r]$
$=(a[1]⊕a[2]⊕a[3]...⊕a[l-1])⊕(a[1]⊕a[2]⊕a[3] ...⊕a[r])$
$=s[l-1]⊕s[r]$,
所以求$l[i]$,转化为找$j<i$,使得$s[j]⊕s[i]$最大。
转化为「LOJ#10050」「一本通 2.3 例 2」The XOR Largest Pair(Trie
以相似的方法可以求出$r[i]$(以$i$开头的区间中,异或值的最大值)。
在实际操作的过程中可以$l[i]=max(l[i-1],find(x))$,这样$ans=max(l[i]+r[i+1])$就行了。
书上的操作是直接$l[i]=find(x)$然后$ans=max(l[i]+r[i+1])$,感觉不能理解qwq
编号 题目 状态 分数 总时间 内存 代码 / 答案文件 提交者 提交时间
# #. 「一本通 2.3 例 」Nikitosh 和异或 Accepted ms KiB C++ / 1.2 K qwerta -- :: #include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std;
int s[];
int l[];
int r[];
struct emm{
int nxt[];
}a[];
int cnt=;
int b[];
void add(int x)
{
int j=-;
memset(b,,sizeof(b));
while(x)
{
b[++j]=x&;
x>>=;
}
int k=;
for(int j=;j>=;--j)
{
if(!a[k].nxt[b[j]])
a[k].nxt[b[j]]=++cnt;
k=a[k].nxt[b[j]];
}
return;
}
int find(int x)
{
int now=,k=;
for(int j=;j>=;--j)
{
if(a[k].nxt[-b[j]])
{
now+=(<<j);
k=a[k].nxt[-b[j]];
}
else k=a[k].nxt[b[j]];
}
return now;
}
int main()
{
//freopen("a.in","r",stdin);
int n;
scanf("%d",&n);
for(int i=;i<=n;++i)
scanf("%d",&s[i]);
int x=;
for(int i=;i<=n;++i)
{
x^=s[i];//这里的x为前缀和
add(x);
l[i]=max(l[i-],find(x));
}
//重做一次找r[i]
memset(a,,cnt+);
x=,cnt=;
for(int i=n;i;--i)
{
x^=s[i];
add(x);
r[i]=max(r[i+],find(x));
}
int ans=;
for(int i=;i<n;++i)
ans=max(ans,l[i]+r[i+]);
cout<<ans;
return ;
}
最新文章
- 《zw版&#183;Halcon-delphi系列原创教程》 Halcon分类函数003&#183;contour,轮廓处理
- asp.net项目下的web service返回json数据问题
- C#跟踪和调试程序-Debug类使用
- 1509: [NOI2003]逃学的小孩 - BZOJ
- 一行命令实现Android自动关机
- windows 配置免安装 node
- C#学习笔记——面向对象、面向组件以及类型基础
- CreateObject(";Wscript.Shell";)用法
- HDU-2176 取(m堆)石子游戏
- Ubantu安装mysql
- ajax删除数据(不跳转页面)
- 从零开始学习PYTHON3讲义(三)写第一个程序
- libc++abi.dylib: terminating with uncaught exception of type NSException (lldb)
- nth-of-type(n)
- Mosquitto-1.5在Linux上的安装以及Android客户端的实现
- 现有各种SSTC电路图,欢迎补充,研究,开发
- 20165326 java实验二
- s5-10 路由
- linux笔记_day10_shell编程
- aop:declare-parents注解