题目链接:BZOJ - 4103

题目分析

THUSC滚粗之后一直没有写这道题,从来没写过可持久化Trie,发现其实和可持久化线段树都是一样的。嗯,有些东西就是明白得太晚。

首先Orz ZYF-ZYF 神犇的题解。

题目给出的 n 和 m 的范围差别很大,n 很小,m 很大,因此可以想到 n 的范围是为了直接暴力枚举。

题目要求的就是 A 的一段区间中的数和 B 的一段区间中的数的异或的第 k 大值。

位运算有关的题目,一般是从高位到低位贪心之类的。

区间异或,一般要使用可持久化 Trie。

我们对于范围大的 B 数组建立可持久化 Trie,这样就可以提取 B 数组的一个区间了。

从高位到低位,枚举 A 数组区间中的每个元素,根据 Trie 结点的信息,求出这一位为 0 和 为 1 的各有多少,并据此确定答案的这一位。

要注意的是,A 数组区间中每个元素要对应的 Trie 结点是不同的,由它们的前几位确定(因为它们的前几位不同,但是要求异或之后前几位相同)。

编辑完这篇博客之后还是一个一个地添加了标签,虽然这个blog马上就要停更了,感觉这几天写的任何一篇都有可能是最后一篇。

奇怪的感觉。

代码

#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <cmath>
#include <algorithm> using namespace std; const int MaxN = 1000 + 5, MaxM = 300000 + 5, MaxNode = 10000000 + 5; int n, m, p, Index, Ans;
int A[MaxN], B[MaxM], Root[MaxM], Son[MaxNode][2], T[MaxNode], F[MaxN], Q[MaxN]; bool OK[MaxN]; void Build(int &x, int y, int Num, int Bit)
{
if (!x) x = ++Index;
if (Bit == 0)
{
T[x] = T[y] + 1;
return;
}
if (Num & (1 << (Bit - 1)))
{
Son[x][0] = Son[y][0];
Build(Son[x][1], Son[y][1], Num, Bit - 1);
}
else
{
Son[x][1] = Son[y][1];
Build(Son[x][0], Son[y][0], Num, Bit - 1);
}
T[x] = T[Son[x][0]] + T[Son[x][1]];
} int main()
{
scanf("%d%d", &n, &m);
for (int i = 1; i <= n; ++i) scanf("%d", &A[i]);
for (int i = 1; i <= m; ++i)
{
scanf("%d", &B[i]);
Build(Root[i], Root[i - 1], B[i], 31);
}
scanf("%d", &p);
int u, d, l, r, kk;
for (int i = 1; i <= p; ++i)
{
scanf("%d%d%d%d%d", &u, &d, &l, &r, &kk);
kk = (d - u + 1) * (r - l + 1) - kk + 1;
Ans = 0;
for (int j = u; j <= d; ++j)
{
F[j] = Root[r];
Q[j] = Root[l - 1];
}
for (int j = 30; j >= 0; --j)
{
int x, Temp = 0;
for (int k = u; k <= d; ++k)
{
x = (A[k] & (1 << j));
if (x) Temp += T[Son[F[k]][1]] - T[Son[Q[k]][1]];
else Temp += T[Son[F[k]][0]] - T[Son[Q[k]][0]];
}
if (Temp >= kk)
{
for (int k = u; k <= d; ++k)
{
x = (A[k] & (1 << j));
if (x)
{
F[k] = Son[F[k]][1];
Q[k] = Son[Q[k]][1];
}
else
{
F[k] = Son[F[k]][0];
Q[k] = Son[Q[k]][0];
}
}
}
else
{
kk -= Temp;
Ans |= (1 << j);
for (int k = u; k <= d; ++k)
{
x = (A[k] & (1 << j));
if (x)
{
F[k] = Son[F[k]][0];
Q[k] = Son[Q[k]][0];
}
else
{
F[k] = Son[F[k]][1];
Q[k] = Son[Q[k]][1];
}
}
}
}
printf("%d\n", Ans);
}
return 0;
}

  

[BZOJ 4103] [Thu Summer Camp 2015] 异或运算 【可持久化Trie】的更多相关文章

  1. BZOJ 4103: [Thu Summer Camp 2015]异或运算 可持久化trie

    开始想了一个二分+可持久化trie验证,比正解多一个 log 仔细思考,你发现你可以直接按位枚举,然后在可持久化 trie 上二分就好了. code: #include <bits/stdc++ ...

  2. [BZOJ4103][Thu Summer Camp 2015]异或运算 可持久化Trie树

    4103: [Thu Summer Camp 2015]异或运算 Time Limit: 20 Sec  Memory Limit: 512 MB Description 给定长度为n的数列X={x1 ...

  3. 【bzoj4103】[Thu Summer Camp 2015]异或运算 可持久化trie树

    Description 给定长度为n的数列X={x1,x2,...,xn}和长度为m的数列Y={y1,y2,...,ym},令矩阵A中第i行第j列的值Aij=xi xor yj,每次询问给定矩形区域i ...

  4. 【BZOJ 4103】 4103: [Thu Summer Camp 2015]异或运算 (可持久化Trie)

    4103: [Thu Summer Camp 2015]异或运算 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 474  Solved: 258 De ...

  5. 【BZOJ 4103】 [Thu Summer Camp 2015]异或运算 可持久化01Trie

    我们观察数据:树套树 PASS    主席树 PASS  一层一个Trie PASS 再看,异或!我们就把目光暂时定在01Tire然后我们发现,我们可以带着一堆点在01Trie上行走,因为O(n*q* ...

  6. BZOJ4103 [Thu Summer Camp 2015]异或运算 【可持久化trie树】

    题目链接 BZOJ4103 题解 一眼看过去是二维结构,实则未然需要树套树之类的数据结构 区域异或和,就一定是可持久化\(trie\)树 观察数据,\(m\)非常大,而\(n\)和\(p\)比较小,甚 ...

  7. bzoj4103 [Thu Summer Camp 2015]异或运算(可持久化trie)

    内存限制:512 MiB 时间限制:1000 ms 题目描述 给定长度为n的数列X={x1,x2,...,xn}和长度为m的数列Y={y1,y2,...,ym},令矩阵A中第i行第j列的值Aij=xi ...

  8. bzoj4103: [Thu Summer Camp 2015]异或运算

    对于每个询问暴力枚举x~y,然后在Trie去找第k大,开始我写了个二分答案然后算比当前答案大的个数,打了个第10个点的表就跑出19s+比bzoj垫底还慢4s+ 然而不用二分,直接1000个点一起在树上 ...

  9. bzoj:4105: [Thu Summer Camp 2015]平方运算

    Description   Input 第一行有三个整数N,M,p,分别代表序列的长度.平方操作与询问操作的总次数以及在平方操作中所要模的数.   接下来一行N个数代表一开始的序列{X1,X2,... ...

随机推荐

  1. [转载]传智播客_SQL入门

    原文地址:传智播客_SQL入门作者:happylonger SQL * 数据定义语言 DDL * 数据操作语言 DML * 查询和更新指令构成了 SQL 的 DML 部分:  * SELECT - 从 ...

  2. job interview

    一 , 7series clock 二, SDRAM comtroller (DDR) 4.熟悉DDR2/3协议或Ethernet相关协议,并有实际项目经验者优先: 三,AXI bus(AMBA) 四 ...

  3. 【itclx面向对象二】窥探itcl面向编程源码

    从上一篇博客看出,itcl的语法其实不难,但是有个缺点,编程习惯与当前类似C++常见的面向编程还是有些区别,并且在大型项目实施中这种方式很费劲. 于是有了itclx. 例如: 1.成员变量.成员方法调 ...

  4. 关于async和await的一些误区实例详解

    转载自 http://www.jb51.net/article/53399.htm 这篇文章主要介绍了关于async和await的一些误区实例详解,有助于更加深入的理解C#程序设计,需要的朋友可以参考 ...

  5. 【转】MyBatis学习总结(四)——解决字段名与实体类属性名不相同的冲突

    [转]MyBatis学习总结(四)——解决字段名与实体类属性名不相同的冲突 在平时的开发中,我们表中的字段名和表对应实体类的属性名称不一定都是完全相同的,下面来演示一下这种情况下的如何解决字段名与实体 ...

  6. Android寒假实训云笔记总结——欢迎页

    欢迎页使用的是viewpager,需要适配器. 注意点: 1.判断是否是第一次进入这个app. 2.欢迎页小圆点的逻辑. 实现原理: 首先在activity_welcome放入viewpager和固定 ...

  7. jsp(一) : servlet基础

    1.客户  servlet容器   servlet 2.实现接口     #1.接口:servlet :             constrontor .init().service.destroy ...

  8. glassfish 日志输出配置

    asadmin set-log-levels javax.enterprise.system.tools.deployment=WARNING

  9. IIS6.0、IIS7中的站点、应用程序和虚拟目录详细介绍

    这里说的不是如何解决路径重写或者如何配置的问题,而是阐述一下站点(site),应用程序(application)和虚拟目录 (virtual directory)概念与作用,已及这三个东西在IIS6与 ...

  10. 用pelican搭建完美博客

    前面有文章介绍本站采用了Python编写的Pelican静态生成博客系统, 之所以没有使用当前很火的Jekyll, 是因为它是Ruby编写, 而我又对Ruby没有啥兴趣, 所以还是选择了使用了我熟悉的 ...