BZOJ 3166 set+可持久化trie树(OR 莫队)
思路:
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 莫队)的更多相关文章
- 主席树||可持久化线段树+离散化 || 莫队+分块 ||BZOJ 3585: mex || Luogu P4137 Rmq Problem / mex
题面:Rmq Problem / mex 题解: 先离散化,然后插一堆空白,大体就是如果(对于以a.data<b.data排序后的A)A[i-1].data+1!=A[i].data,则插一个空 ...
- bzoj 3261: 最大异或和 (可持久化trie树)
3261: 最大异或和 Time Limit: 10 Sec Memory Limit: 512 MB Description 给定一个非负整数序列 {a},初始长度为 N. ...
- BZOJ 3261 最大异或和 可持久化Trie树
题目大意:给定一个序列,提供下列操作: 1.在数组结尾插入一个数 2.给定l,r,x,求一个l<=p<=r,使x^a[p]^a[p+1]^...^a[n]最大 首先我们能够维护前缀和 然后 ...
- [BZOJ3261&BZOJ3166]可持久化trie树及其应用
可持久化trie树 可持久化trie树现在想来是比较好理解的了,但却看了一个下午... 相当于对于每个状态建立一条链(或者说一棵trie),求解的时候只要让两个点按照相同的步子走然后看sum的大小关系 ...
- 可持久化Trie树初步
可持久化Trie树和可持久化线段树很像,依次插入信息,通过减法来进行历史版本查询. 2015年11月27日 bzoj3261 最大异或和 我们需要计算 a[p] xor a[p+1] xor ... ...
- [十二省联考2019]异或粽子——可持久化trie树+堆
题目链接: [十二省联考2019]异或粽子 求前$k$大异或区间,可以发现$k$比较小,我们考虑找出每个区间. 为了快速得到一个区间的异或和,将原序列做前缀异或和. 对于每个点作为右端点时,我们维护出 ...
- BZOJ4477[Jsoi2015]字符串树——可持久化trie树
题目描述 萌萌买了一颗字符串树的种子,春天种下去以后夏天就能长出一棵很大的字符串树.字符串树很奇特,树枝上都密密麻麻写满了字符串,看上去很复杂的样子.[问题描述]字符串树本质上还是一棵树,即N个节点N ...
- BZOJ5338 [TJOI2018] Xor 【可持久化Trie树】【dfs序】
题目分析: 很无聊的一道题目.首先区间内单点对应异或值的询问容易想到trie树.由于题目在树上进行,case1将路径分成两段,然后dfs的时候顺便可持久化trie树做询问.case2维护dfs序,对d ...
- 51nod 1295 XOR key (可持久化Trie树)
1295 XOR key 题目来源: HackerRank 基准时间限制:1.5 秒 空间限制:262144 KB 分值: 160 难度:6级算法题 给出一个长度为N的正整数数组A,再给出Q个查 ...
随机推荐
- 在centos上安装php5.5+MySQL 5.5.32
在centos直接使用yum install 安装php的话版本比较低,如果需要高版本的话,请看如下: Step 1: Installing Remi Repository ## Install Re ...
- 脚本_求和100以内的正整数.sh
#!bin/bash#功能:求和100以内的正整数#作者:liusingbon#seq 100 可以快速自动生成 100 个整数sum=0for i in $(seq 100)do sum=$[ ...
- @DateTimeFormat无效原因
一般都是使用@DateTimeFormat把传给后台的时间字符串转成Date,使用@JsonFormat把后台传出的Date转成时间字符串,但是@DateTimeFormat只会在类似@Request ...
- 测试用html
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- Unity5.X 开发资源介绍
Asset 资源 Category 类别 Publisher 开发商 Rating 评级 Version 版本号 Windows → Asset Store 资源商店 [Ctrl + 9] U ...
- Java 应用运维
作者:http://blogread.cn/it/article/4918?f=wb 出处:http://blogread.cn/it/article/4918?f=wb Java应用运维 出处 ...
- Vue学习之路第三篇:插值表达式和v-text的区别
上一篇说到插值表达式有一个问题: 页面频繁刷新或者网速加载很慢的时候,页面会先出现“{{ msg }}”,再一闪而过出现真实的数据. 对于这个问题Vue给予了解决办法,看具体事例. <div i ...
- These relative modules were not found:...{"sourceM ap":false} 报错解决
今天在使用vue2.0 + webpack 时,没有动过任何配置文件,也没更新依赖,但是报下面的错误: These relative modules were not found: * ./star1 ...
- 一些BFC
我们可能会遇到这样的一些问题,比如:子元素浮动,父元素高度塌陷:父元素跟随子元素一起移动等 这是我们可以通过触发BFC来解决这样的问题. BFC为"块级格式化上下文".它是一个独立 ...
- POJ 3517 And Then There Was One( 约瑟夫环模板 )
链接:传送门 题意:典型约瑟夫环问题 约瑟夫环模板题:n个人( 编号 1-n )在一个圆上,先去掉第m个人,然后从m+1开始报1,报到k的人退出,剩下的人继续从1开始报数,求最后剩的人编号 /**** ...