P3293 [SCOI2016]美味

题意:

有n个数组a,现在有m个询问,每次给出一个b和x,问b xor (a[i] + x)的最大值是多少?

题解:

不难看出01Trie的题目
我们设ans=a[i]+x,我们想要b xor ans的最大值,这个很好说经典套路,如果b的第i位是1,我们就希望ans的第i位是0,此时我们希望ans是张这样子的:

这样不难求出a[j]的范围:a[j]∈[ans-x,ans-x+(1<<i+1)-1]
此时我们就看这个区间内是否存在a[j]满足情况,也就是看这个区间内是否有数组a存在,主席树可以解决这个问题
总结:

当b的第i位是1时,若有这样一个a[i],ans+=0<<i,反之ans+=1<<i
当b的第i位是0时,若有这样一个a[i],ans+=1<<i,反之ans+=0<<i

代码:

#include<bits/stdc++.h>
#define debug(a,b) printf("%s = %d\n",a,b);
using namespace std;
typedef long long ll;
typedef pair<int, int> PII;
clock_t startTime, endTime;
//Fe~Jozky
const ll INF_ll=1e18;
const int INF_int=0x3f3f3f3f;
inline ll read(){ll s=0,w=1ll;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')w=-1ll;ch=getchar();}while(ch>='0'&&ch<='9') s=s*10ll+((ch-'0')*1ll),ch=getchar();//s=(s<<3)+(s<<1)+(ch^48);return s*w;
}
void rd_test(){#ifdef ONLINE_JUDGE#elsestartTime = clock(); //计时开始freopen("in.txt","r",stdin);#endif
}
void Time_test(){#ifdef ONLINE_JUDGE#elseendTime = clock(); //计时结束printf("\n运行时间为:%lfs\n",(double)(endTime - startTime) / CLOCKS_PER_SEC);#endif
}
const int maxn=5e5+9;
int a[maxn],rt,t[maxn<<6],ch[maxn<<5][2],sum[maxn<<5];
int maxx=0;
void update(int &now,int pre,int l,int r,int x){if(r<x||l>x)return ;now=++rt;ch[now][0]=ch[pre][0];ch[now][1]=ch[pre][1];sum[now]=sum[pre]+1;if(l==r)return;int mid=l+r>>1;update(ch[now][0],ch[pre][0],l,mid,x);update(ch[now][1],ch[pre][1],mid+1,r,x);
}
int query(int Ltree,int Rtree,int l,int r,int x,int y){int num=sum[Rtree]-sum[Ltree];if(y<l||x>r||num==0)return 0;if(x<=l&&r<=y)return num;int mid=l+r>>1;return query(ch[Ltree][0],ch[Rtree][0],l,mid,x,y)+query(ch[Ltree][1],ch[Rtree][1],mid+1,r,x,y);
}
int get(int b,int x,int l,int r){int ans=0;for(int i=30;i>=0;i--){int c=((b>>i)&1);if(c==1&&(!query(t[l-1],t[r],0,maxx,ans-x,ans-x+(1<<i)-1)))ans+=(1<<i);if(c==0&&(query(t[l-1],t[r],0,maxx,ans-x+(1<<i),ans-x+(1<<(i+1))-1)))ans+=(1<<i);}return ans;
}
int main()
{//rd_test();int n,m,q;cin>>n>>q;for(int i=1;i<=n;i++){cin>>a[i];maxx=max(a[i],maxx);}t[0]=0;for(int i=1;i<=n;i++){update(t[i],t[i-1],0,maxx,a[i]);}while(q--){int b,x,l,r;cin>>b>>x>>l>>r;int ans=get(b,x,l,r);printf("%d\n",ans^b);}//Time_test();
}

P3293 [SCOI2016]美味相关推荐

  1. trie树上值域化建主席树 查询异或平移最小值 ---- P3293 [SCOI2016]美味

    题目大意: 解题思路: 首先我们知道区间查询异或最小值肯定是在trie是匹配 而且如果没有(aj+xi)(aj+xi)(aj+xi)就是一个可持久化Trie树上面的裸题了 但是很不幸有 怎么办呢? 首 ...

  2. luogu P3293 [SCOI2016]美味

    传送门 异或最大值应该是要用\(trie\)树,从高位往低位贪心,虽然这里询问区间的数都要加上\(x\),但是仍然可以利用这个思想 从高往低位考虑,我们要找一个加上\(x\)后当前二进制位\(j\)不 ...

  3. P3293 [SCOI2016]美味 主席树 + 伪01trie

    传送门 文章目录 题意: 思路: 题意: 思路: 看到异或的话,很容易想到用01trie来贪心的搞,但是这个题涉及区间问题,直接搞的话需要将[l,r][l,r][l,r]的数都插入trie里面,这样的 ...

  4. 洛谷·[SCOI2016]美味

    初见安~这里是传送门:洛谷P3293 [SCOI2016]美味 题解 首先看到有两层限制:区间[l, r]以及要异或值最大.很显然把区间限制转化到时间限制,建可持久化数据结构. 每道菜对不同的人有不同 ...

  5. bzoj [Scoi2016]美味

    [Scoi2016]美味 Time Limit: 30 Sec  Memory Limit: 256 MB Submit: 721  Solved: 391 [Submit][Status][Disc ...

  6. BZOJ4571:[SCOI2016]美味——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=4571 https://www.luogu.org/problemnew/show/P3293 一家 ...

  7. [BZOJ 4571][Scoi2016]美味(主席树)

    Description 一家餐厅有 n 道菜,编号 1...n ,大家对第 i 道菜的评价值为 ai(1≤i≤n).有 m 位顾客,第 i 位顾客的期 望值为 bi,而他的偏好值为 xi .因此,第 ...

  8. 可持久化3--可持久化01Trie

    01Trie 可持久化 01Trie 的方式和可持久化值域线段树的方式是相似的,只是以 01字典树 的方式来维护值域.一般用来解决异或相关的能够按位贪心的题目. 其实就是将可持久化线段树中的操作嫁接到 ...

  9. 自备ACM模板 —— 数据结构篇

    文章目录 ST表 线段树 区间加.区间乘混合 主席树 主席树+差分 主席树查询区间前K项前缀和 带修主席树 树上主席树 带修树上主席树 主席树判断存在性问题 二分套主席树 区间修改+标记永久化+树状数 ...

最新文章

  1. mysql日期函数 简书_ios怎样搭建php服务器
  2. 136个Python 机器学习知识点让你受益终生!
  3. SAP Kyma和Marketing Cloud的连接 - Marketing Cloud里的配置
  4. python语言精通_Python语言基础从入门到精通
  5. ovation系统服务器安装,Ovation系统介绍.ppt
  6. Python函数中单独一个星号或斜线作为形参的含义
  7. linux execl 错误信息,Excel:自动隐藏错误结果的显示信息(转)
  8. 基于OpenCV的计算机视觉入门(3)图像特效
  9. 【渝粤教育】国家开放大学2019年春季 0755-22T学前儿童艺术教育 参考试题
  10. centos7搭建ELK Cluster集群日志分析平台(四):Fliebeat-简单测试
  11. 应用RSACryptoServiceProvider类轻松实现RSA算法
  12. OpenGL ES 中的模板测试
  13. Linux连接锐捷校园网客户端
  14. 用 Delphi 下载网络文件
  15. Web前端性能优化策略
  16. win10上Redis设置密码
  17. iOS微信分享及Universal Links
  18. Keep熬过冬天,但互联网健身的生意依然不好做
  19. 7、osg中响应键盘鼠标事件以及鼠标和键盘编码表
  20. 《iPad开发从入门到精通》——6.4节收藏历史

热门文章

  1. 那一年,爱因斯坦输得很惨很惨,被十几个诺奖得主怼了一遍后,退出了群聊……...
  2. 老师“鬼话”全曝光!哈哈哈哈哈全国的老师都这样吗?
  3. 战斗机各种世界之最,涨知识了。。。
  4. TensorFlow的这些骚操作你都知道吗?
  5. redis查看key的过期时间_面试官:你在Redis中设置过带过期时间的Key吗?
  6. c语言复数的运算实验报告,C语言复数的运算(实验报告).doc
  7. python 中文编码差异_Python 编码为什么那么蛋疼?
  8. java 声明变量构成_Java—变量
  9. centos rpm 安装 perl_Linux【常用软件安装篇】
  10. [RabbitMQ]工作原理_原理名词解释