思路:

1.找次大值 我们不妨设当前点是次大的 那这段区间为 左边第二个比它大的点的坐标+1 和右边第二个比它大的点的坐标-1

2.用可持久化trie树找异或最大值

也可以用莫队

//By SiriusRen
#include <set>
#include <cstdio>
#include <algorithm>
using namespace std;
#define N 50050
int n,cnt,f,ch[N*32][2],wei[N*32],root[N];
int begin,end,ans;
void insert(int last,int num){
int now=cnt;
for(int i=30;i>=0;i--){
f=num&(1<<i)?1:0;
ch[now][f]=++cnt,ch[now][!f]=ch[last][!f];
now=ch[now][f],last=ch[last][f];
wei[now]=wei[last]+1;
}
}
int query(int x,int y,int num){
int temp=0;
for(int i=30;i>=0;i--){
f=num&(1<<i)?0:1;
if(wei[ch[y][f]]-wei[ch[x][f]]>0)
x=ch[x][f],y=ch[y][f],temp+=(1<<i);
else x=ch[x][!f],y=ch[y][!f];
}return temp;
}
struct Node{int id,w;}a[N];
bool operator<(Node a,Node b){return a.w>b.w;}
set<int>st;
set<int>::iterator it1,it2;
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%d",&a[i].w),a[i].id=i;
root[i]=++cnt;insert(root[i-1],a[i].w);
}
st.insert(-1),st.insert(-2),st.insert(N),st.insert(n+1);
sort(a+1,a+1+n),st.insert(a[1].id);
for(int i=2;i<=n;i++){
st.insert(a[i].id);
it2=st.lower_bound(a[i].id);
it1=it2,it2++,it2++,it1--,it1--;
begin=max(1,*it1+1),end=min(n,*it2-1);
ans=max(ans,query(root[begin-1],root[end],a[i].w));
}
printf("%d\n",ans);
}

莫队(是稍微慢一些的……):

//By SiriusRen
#include <set>
#include <cstdio>
#include <algorithm>
using namespace std;
#define N 50050
int n,cnt=1,b[N],f,ch[N*32][2],wei[N*32],root[N];
int begin,end,ans,tot;
struct Node{int id,w;}a[N];
bool operator<(Node a,Node b){return a.w>b.w;}
set<int>st;
set<int>::iterator it1,it2;
struct Ask{int l,r,w;}ask[N];
bool operator<(Ask a,Ask b){return a.l<b.l;}
void insert(int x,int w){
int now=1;
for(int i=30;i>=0;i--){
f=x&(1<<i)?1:0;
if(!ch[now][f])ch[now][f]=++cnt;
now=ch[now][f],wei[now]+=w;
}
}
int query(int num){
int now=1,temp=0;
for(int i=30;i>=0;i--){
f=num&(1<<i)?0:1;
if(ch[now][f]&&wei[ch[now][f]])temp+=(1<<i),now=ch[now][f];
else now=ch[now][!f];
}return temp;
}
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++)scanf("%d",&b[i]),a[i].w=b[i],a[i].id=i;
st.insert(-1),st.insert(-2),st.insert(N),st.insert(n+1);
sort(a+1,a+1+n),st.insert(a[1].id);
for(int i=2;i<=n;i++){
st.insert(a[i].id);
it2=st.lower_bound(a[i].id);
it1=it2,it2++,it2++,it1--,it1--;
begin=max(1,*it1+1),end=min(n,*it2-1);
ask[++tot].l=begin-1,ask[tot].r=end,ask[tot].w=a[i].w;
}
sort(ask+1,ask+1+tot);
for(int i=1,l=1,r=0;i<=tot;i++){
while(r<ask[i].r)insert(b[r+1],1),r++;
while(r>ask[i].r)insert(b[r],-1),r--;
while(l<ask[i].l)insert(b[l],-1),l++;
while(l>ask[i].l)insert(b[l-1],1),l--;
ans=max(ans,query(ask[i].w));
}
printf("%d\n",ans);
}

BZOJ 3166 set+可持久化trie树(OR 莫队)的更多相关文章

  1. 主席树||可持久化线段树+离散化 || 莫队+分块 ||BZOJ 3585: mex || Luogu P4137 Rmq Problem / mex

    题面:Rmq Problem / mex 题解: 先离散化,然后插一堆空白,大体就是如果(对于以a.data<b.data排序后的A)A[i-1].data+1!=A[i].data,则插一个空 ...

  2. bzoj 3261: 最大异或和 (可持久化trie树)

    3261: 最大异或和 Time Limit: 10 Sec  Memory Limit: 512 MB Description       给定一个非负整数序列 {a},初始长度为 N.       ...

  3. BZOJ 3261 最大异或和 可持久化Trie树

    题目大意:给定一个序列,提供下列操作: 1.在数组结尾插入一个数 2.给定l,r,x,求一个l<=p<=r,使x^a[p]^a[p+1]^...^a[n]最大 首先我们能够维护前缀和 然后 ...

  4. [BZOJ3261&BZOJ3166]可持久化trie树及其应用

    可持久化trie树 可持久化trie树现在想来是比较好理解的了,但却看了一个下午... 相当于对于每个状态建立一条链(或者说一棵trie),求解的时候只要让两个点按照相同的步子走然后看sum的大小关系 ...

  5. 可持久化Trie树初步

    可持久化Trie树和可持久化线段树很像,依次插入信息,通过减法来进行历史版本查询. 2015年11月27日 bzoj3261 最大异或和 我们需要计算 a[p] xor a[p+1] xor ... ...

  6. [十二省联考2019]异或粽子——可持久化trie树+堆

    题目链接: [十二省联考2019]异或粽子 求前$k$大异或区间,可以发现$k$比较小,我们考虑找出每个区间. 为了快速得到一个区间的异或和,将原序列做前缀异或和. 对于每个点作为右端点时,我们维护出 ...

  7. BZOJ4477[Jsoi2015]字符串树——可持久化trie树

    题目描述 萌萌买了一颗字符串树的种子,春天种下去以后夏天就能长出一棵很大的字符串树.字符串树很奇特,树枝上都密密麻麻写满了字符串,看上去很复杂的样子.[问题描述]字符串树本质上还是一棵树,即N个节点N ...

  8. BZOJ5338 [TJOI2018] Xor 【可持久化Trie树】【dfs序】

    题目分析: 很无聊的一道题目.首先区间内单点对应异或值的询问容易想到trie树.由于题目在树上进行,case1将路径分成两段,然后dfs的时候顺便可持久化trie树做询问.case2维护dfs序,对d ...

  9. 51nod 1295 XOR key (可持久化Trie树)

    1295 XOR key  题目来源: HackerRank 基准时间限制:1.5 秒 空间限制:262144 KB 分值: 160 难度:6级算法题   给出一个长度为N的正整数数组A,再给出Q个查 ...

随机推荐

  1. [SCOI 2005] 栅栏

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1082 [算法] 首先二分“最多得到的符合条件的木板数”,检验时可以使用DFS,但是, ...

  2. Python学习历程之模块浅识

    # =============================操作系统模块=======================# import os# 待续# ======================= ...

  3. 5.文件I/O

    1 C标准函数与系统函数的区别 文件的结构体: 1.1 I/O缓冲区 每一个FILE文件流都有一个缓冲区buffer,默认大小8192Byte. 1.2 效率 文件缓冲区会降低效率.这里提供缓冲区主要 ...

  4. 如何版本化你的API?--转

    原文地址:http://www.infoq.com/cn/news/2017/09/How-versioning-API 如何版本化API需要考虑各种实际业务场景,但是一个完备的API应该是: 和客户 ...

  5. 判断是否是Ajax请求

    Request.IsAjaxRequest()判断是否是ajax请求原理:Http协议上有个X-Requested-With:XML HttpRequest属性判断的 mvc后台通过Request可以 ...

  6. javascript中手风琴特效

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  7. Python爬虫:爬取糗事百科

    网上看到的教程,但是是用正则表达式写的,并不能运行,后面我就用xpath改了,然后重新写了逻辑,并且使用了双线程,也算是原创了吧#!/usr/bin/python# -*- encoding:utf- ...

  8. MobilNnet

    一.参数数量和理论计算量 1.定义 参数数量(params):关系到模型大小,单位通常为M,通常参数用 float32 表示,也就是每个参数占4个字节,所以模型大小是参数数量的 4 倍 理论计算量(F ...

  9. 2019-03-18 Python time 将2015年11月20日转换为2015-11-20

    #ReportingDate = soup.select('body > div.main > div > div.ctr > div.recruit > ul > ...

  10. async、await 优缺点

    async.await 优缺点 async 和 await 相比直接使用 Promise 来说,优势在于处理 then 的调用链,能够更清晰准确的写出代码.缺点在于滥用 await 可能会导致性能问题 ...