XOR Queries(莫队+trie)
题目链接:
给出一个长度为nn的数组CC,回答mm个形式为(L, R, A, B)(L,R,A,B)的询问,含义为存在多少个不同的数组下标k \in [L, R]k∈[L,R]满足C[k] \bigoplus A \geq BC[k]⨁A≥B(式中\bigoplus⨁为异或运算)。
输入描述
输入第一行为一个整数TT,表示一共有TT组测试数据。
对于每组测试数据:
第一行为两个整数nn,mm(1 \leq n, m \leq 500001≤n,m≤50000)。
第二行为nn个整数表示数组CC(0 \leq C[i] \leq 10^{9}0≤C[i]≤109)。
接下来mm行中,第ii行有四个整数L_{i}Li,R_{i}Ri,A_{i}Ai,B_{i}Bi(1 \leq L_{i} \leq R_{i} \leq n1≤Li≤Ri≤n, 0 \leq A_{i}, B_{i} \leq 10^{9}0≤Ai,Bi≤109)。
输出描述
对于每次询问:输出一个整数表示满足条件的数组下标数目。
样例输入
1
5 2
1 2 3 4 5
1 3 1 1
2 5 2 3
样例输出
2
2 题意:给出一个数列,然后m个询问,每一询问是问这个区间里面有多少个a[k]^A>=B;
思路:显然是一个莫队,trie树里面存的是当前区间里面的数,所以需要trie的insert和del操作,
然后就是询问这个区间里面有多少个异或大于等于B就贪心就好了,注意最后相等的情况,需要写个query就好;
AC代码:
#include <bits/stdc++.h>
using namespace std;
const int maxn=5e4+10;
int n,m,a[maxn],ans[maxn];
struct node
{
int l,r,a,b,id,sq;
}po[maxn];
int cmp(node x,node y)
{
if(x.sq==y.sq)return x.r<y.r;
return x.l<y.l;
}
int ch[31*maxn][2],val[31*maxn];
int sz;
inline void init()
{
sz=1;
memset(ch[0],0,sizeof(ch[0]));
}
inline void insert(int x)
{
int u=0,len=30;
for(int i=len;i>=0;i--)
{
int c=((x>>i)&1);
if(!ch[u][c])
{
memset(ch[sz],0,sizeof(ch[sz]));
val[sz]=0;
ch[u][c]=sz++;
}
u=ch[u][c];
val[u]++;
}
}
inline void Delete(int x)
{
int u=0,len=30;
for(int i=len;i>=0;i--)
{
int c=((x>>i)&1);
u=ch[u][c];
val[u]--;
}
}
inline int query(int A,int B)
{
int u=0,len=30,sum=0,flag;
for(int i=len;i>=0;i--)
{
int c=((A>>i)&1),d=((B>>i)&1);
int ha=u;
if(ch[u][1]&&(c^1)>d)
{
int tep=ch[u][1];
sum=sum+val[tep];
}
if(ch[u][0]&&(c^0)>d)
{
int tep=ch[u][0];
sum=sum+val[tep];
}
flag=0;
if(ch[u][1]&&(c^1)==d)u=ch[u][1],flag=1;
if(ch[u][0]&&(c^0)==d)u=ch[u][0],flag=1;
if(ha==u)break;
}
if(flag)sum=sum+val[u];
return sum;
}
int main()
{
//freopen("in.txt","r",stdin);
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
init();
int sq=sqrt(n*1.0);
for(int i=1;i<=n;i++)scanf("%d",&a[i]);
for(int i=1;i<=m;i++)
{
scanf("%d%d%d%d",&po[i].l,&po[i].r,&po[i].a,&po[i].b);
po[i].id=i;po[i].sq=po[i].l/sq;
}
sort(po+1,po+m+1,cmp);
int l=1,r=0;
for(int i=1;i<=m;i++)
{
while(r<po[i].r)r++,insert(a[r]);
while(r>po[i].r)Delete(a[r]),r--;
while(l<po[i].l)Delete(a[l]),l++;
while(l>po[i].l)l--,insert(a[l]);
ans[po[i].id]=query(po[i].a,po[i].b);
}
for(int i=1;i<=m;i++)printf("%d\n",ans[i]);
}
return 0;
}
XOR Queries(莫队+trie)的更多相关文章
- XOR (莫队)
Time Limit: 2000 ms Memory Limit: 256 MB Description 给定一个含有n个整数的序列 a1, a2,..., an. 定义 f(x,x) = a[x ...
- Sona && Little Elephant and Array && Little Elephant and Array && D-query && Powerful array && Fast Queries (莫队)
vjudge上莫队专题 真的是要吐槽自己(自己的莫队手残写了2个bug) s=sqrt(n) 是元素的个数而不是询问的个数(之所以是sqrt(n)使得左端点每个块左端点的范围嘴都是sqrt(n)) 在 ...
- CodeForces 375D Tree and Queries 莫队||DFS序
Tree and Queries 题意:有一颗以1号节点为根的树,每一个节点有一个自己的颜色,求出节点v的子数上颜色出现次数>=k的颜色种类. 题解:使用莫队处理这个问题,将树转变成DFS序区间 ...
- 7.11 NOI模拟赛 qiqi20021026的T1 四个指针莫队 trie树
LINK:qiqi20021026的T1 考场上只拿到了50分的\(nq\)暴力. 考虑一个区间和一个区间配对怎么做 二分图最大带权匹配复杂度太高. 先考虑LCS的问题 常见解决方法是后缀数组/tri ...
- CFGym101138D Strange Queries 莫队/分块
正解:莫队/分块 解题报告: 传送门 ummm这题耗了我一天差不多然后我到现在还没做完:D 而同机房的大佬用了一个小时没有就切了?大概这就是大佬和弱鸡的差距趴QAQ 然后只是大概写下思想好了因为代码我 ...
- cf375D. Tree and Queries(莫队)
题意 题目链接 给出一棵 n 个结点的树,每个结点有一个颜色 c i . 询问 q 次,每次询问以 v 结点为根的子树中,出现次数 ≥k 的颜色有多少种.树的根节点是1. Sol 想到了主席树和启发式 ...
- [Codeforces375D]Tree and Queries(莫队算法)
题意:给定一棵树,每个节点有颜色,对于每个询问(u,k)询问以u为根节点的子树下有多少种颜色出现次数>=k 因为是子树,跟dfs序有关,转化为一段区间,可以用莫队算法求解 直接用一个数组统计出现 ...
- Codeforces617 E . XOR and Favorite Number(莫队算法)
XOR and Favorite Number time limit per test: 4 seconds memory limit per test: 256 megabytes input: s ...
- Codeforeces 617E XOR and Favorite Number(莫队+小技巧)
E. XOR and Favorite Number time limit per test 4 seconds memory limit per test 256 megabytes input s ...
随机推荐
- 20145329 《Java程序设计》第九周学习总结
教材学习内容总结 十六章 1.Metadata即"诠读数据的数据",数据库是用来存储数据的地方,然而数据库本身产品名称为何?数据库中有几个数据表格?表格名称为何?表格中有几个字段等 ...
- spi nor flash使用汇总
Overview SPI flash, 分为spi flash, DUAL spi flash, QUAD spi flash, 3-wire spi, 4-wire spi, 6-wire spi. ...
- An Example for Javascript Function Scoping and Closure
1. An Real World Example In the patron detail page of the CRM system I'm working with, there’re larg ...
- 分析ReentrantLock的实现原理
http://www.jianshu.com/p/fe027772e156 什么是AQS AQS即是AbstractQueuedSynchronizer,一个用来构建锁和同步工具的框架,包括常用的Re ...
- jQuery Ajax总结
jQuery对Ajax的操作进行了封装.jQuery中\(.ajax()属于最底层的方法,这个放在后面说,首先看看封装了\).ajax()的方法. load()方法 load()可以远程载入HTML并 ...
- C#错误的面试题
你面试的时候是不是碰到这样的问题 String s = new String("xyz");创建了几个String Object? ,对于这个问题,我之前也一直以为是对的,这样写是 ...
- Python基础笔记系列十:模块
本系列教程供个人学习笔记使用,如果您要浏览可能需要其它编程语言基础(如C语言),why?因为我写得烂啊,只有我自己看得懂!! 模块 #1.类比于java中的jar包,模块能让你能够有逻辑地组织你的Py ...
- LeetCode第[84]题(Java):Largest Rectangle in Histogram(最大的矩形柱状图)
题目:最大的矩形柱状图 难度:hard 题目内容: Given n non-negative integers representing the histogram's bar height wher ...
- 一个很有用的树形控件----zTree
演示地址 http://www.treejs.cn/v3/demo.php#_101
- Django框架学习笔记(windows环境下安装)
博主最近开始学习主流框架django 网上大部分的安装环境都linux的 由于博主在windows环境下已经有了 Pycharm编辑器 ,所以决定还是继续在windows环境下学习 首先是下载 链接 ...