【35.20%】【CF 706D】Vasiliy's Multiset
4 seconds
256 megabytes
standard input
standard output
Author has gone out of the stories about Vasiliy, so here is just a formal task description.
You are given q queries and a multiset A,
initially containing only integer 0. There are three types of queries:
- "+ x" — add integer x to multiset A.
- "- x" — erase one occurrence of integer x from
multiset A. It's guaranteed that at least one x is
present in the multiset A before this query. - "? x" — you are given integer x and
need to compute the value ,
i.e. the maximum value of bitwise exclusive OR (also know as XOR) of integer x and some integer y from
the multiset A.
Multiset is a set, where equal elements are allowed.
The first line of the input contains a single integer q (1 ≤ q ≤ 200 000) —
the number of queries Vasiliy has to perform.
Each of the following q lines of the input contains one of three characters '+',
'-' or '?' and an integer xi (1 ≤ xi ≤ 109).
It's guaranteed that there is at least one query of the third type.
Note, that the integer 0 will always be present in the set A.
For each query of the type '?' print one integer — the maximum value of bitwise exclusive OR (XOR) of integer xi and
some integer from the multiset A.
10
+ 8
+ 9
+ 11
+ 6
+ 1
? 3
- 8
? 3
? 8
? 11
11
10
14
13
After first five operations multiset A contains integers 0, 8, 9, 11, 6 and 1.
The answer for the sixth query is integer —
maximum among integers , , , and .
【题解】
如果题目没看懂就看一下上面那个note的样例解释嘛。应该知道是什么意思了吧。
然后我把样例的前6个操作数的二进制列举一下。
如果不足4位就前面补0
1000
1001
1011
0110
0001
询问0011
思路是这样的
把前面5个数字加入字典树中。
然后从根节点开始。看到询问的二进制第一位是0.
0的话xor什么最好呢?当然是1.
那就看看从根节点往下有没有一个1有就往下走,没有的话就走0(0是一直存在的。所以肯定可以走);然后二进制的第二位也以此类推。
最后我们走到底的肯定是最大值。
这里涉及到一个原理就是
(二进制)
1000 > 0111
即2^x > 2^(x-1)+2^(x-2) + ...+ 2^0
实际上左边那个等于右边加1.
节点加入和删除的话
给每个节点都设置一个值。走到这个点就增加一下这个节点的值。然后要删除的时候仍旧走一遍这个路。然后递减路上走过的节点的值。
这3个操作其实很像的。
然后10^9 二进制的长度为30
【代码】
#include <cstdio> const int MAX_SIZE = 7000000; int q, v[MAX_SIZE][2] = { 0 }, totn = 0, num[MAX_SIZE] = { 0 };
int a[40]; //v[t][0],v[t][1]分别表示t的左右儿子,左儿子代表0 void add(int x)
{
int temp = 0, temp1 = x;
a[0] = 30;
while (temp1 > 0) //从后往左加入二进制各个位
{
a[a[0]] = temp1 & 1;
temp1 = temp1 >> 1;
a[0]--;
}
for (int i = 1; i <= a[0]; i++)//1..a[0]是补0
{
if (v[temp][0] == 0)
v[temp][0] = ++totn;
temp = v[temp][0];
num[temp]++;
}
for (int i = a[0] + 1; i <= 30; i++)//a[0]+1..30才是这个数的二进制
{
if (v[temp][a[i]] == 0)
v[temp][a[i]] = ++totn;
temp = v[temp][a[i]];
num[temp]++;
}
} void de_lete(int x)
{
int temp = 0, temp1 = x;
a[0] = 30;
while (temp1 > 0)
{
a[a[0]] = temp1 & 1;
temp1 = temp1 >> 1;
a[0]--;
}
for (int i = 1; i <= a[0]; i++)
{
temp = v[temp][0];
num[temp]--;
}
for (int i = a[0] + 1; i <= 30; i++)
{
temp = v[temp][a[i]];
num[temp]--;
}
} int query(int x)
{
int temp = 0, temp1 = x;
a[0] = 30;
while (temp1 > 0)
{
a[a[0]] = temp1 & 1;
temp1 = temp1 >> 1;
a[0]--;
}
int leijia = 0;
for (int i = 1; i <= a[0]; i++)
if (v[temp][1] != -1 && num[v[temp][1]] > 0)
{
temp = v[temp][1];
leijia += 1 << (30 - i); //代表2^(30-i)
}
else
temp = v[temp][0];
for (int i = a[0] + 1; i <= 30; i++)
if (v[temp][1 - a[i]] != -1 && num[v[temp][1 - a[i]]] > 0)
{
temp = v[temp][1 - a[i]];
leijia += 1 << (30 - i);
}
else
temp = v[temp][a[i]];
return leijia;
} void input_data()
{
scanf("%d", &q);
for (int i = 1; i <= q; i++)
{
char op[5];
int x;
scanf("%s%d", op, &x);
if (op[0] == '+')
add(x);
else
if (op[0] == '-')
de_lete(x);
else
printf("%d\n", query(x));
}
} int main()
{
//freopen("F:\\rush.txt", "r", stdin);
add(0);
input_data();
return 0;
}
【35.20%】【CF 706D】Vasiliy's Multiset的更多相关文章
- codeforces 706D D. Vasiliy's Multiset(trie树)
题目链接: D. Vasiliy's Multiset time limit per test 4 seconds memory limit per test 256 megabytes input ...
- 【codeforces】【比赛题解】#851 CF Round #432 (Div.2)
cf真的难…… 点我浏览丧题. [A]Arpa和她对墨西哥人浪的研究 Arpa正在对墨西哥人浪进行研究. 有n个人站成一排,从1到n编号,他们从时刻0开始墨西哥人浪. 在时刻1,第一个人站起来.在时刻 ...
- JAVA 基础编程练习题20 【程序 20 求前 20 项之和】
20 [程序 20 求前 20 项之和] 题目:有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列的前 20 项之和. 程序分析:请抓住分子与分母的变化规律. pac ...
- 【字典树】【贪心】Codeforces 706D Vasiliy's Multiset
题目链接: http://codeforces.com/contest/706/problem/D 题目大意: 三种操作,1.添加一个数,2.删除一个数,3.查询现有数中与x异或最大值.(可重复) 题 ...
- 【CF 453A】 A. Little Pony and Expected Maximum(期望、快速幂)
A. Little Pony and Expected Maximum time limit per test 1 second memory limit per test 256 megabytes ...
- 【实战Java高并发程序设计6】挑战无锁算法:无锁的Vector实现
[实战Java高并发程序设计 1]Java中的指针:Unsafe类 [实战Java高并发程序设计 2]无锁的对象引用:AtomicReference [实战Java高并发程序设计 3]带有时间戳的对象 ...
- 【实战Java高并发程序设计 3】带有时间戳的对象引用:AtomicStampedReference
[实战Java高并发程序设计 1]Java中的指针:Unsafe类 [实战Java高并发程序设计 2]无锁的对象引用:AtomicReference AtomicReference无法解决上述问题的根 ...
- 【Android】【录音】Android录音--AudioRecord、MediaRecorder
[Android][录音]Android录音--AudioRecord.MediaRecorder Android提供了两个API用于实现录音功能:android.media.AudioRecord. ...
- 【转】从外行的视角尝试讲解为什么这回丰田栽了【全文完】【v1.01】
转自:http://club.tgfcer.com/thread-6817371-1-1.html [第一部分]背景简介 前几年闹得沸沸扬扬的丰田刹不住事件最近又有新进展.十月底俄克拉荷马的一次庭审 ...
随机推荐
- ip地址个数的计算
一个IP地址,却关联太多的知识 二进制与 8 比特 电脑中显示出来的数字是 10 进制的,键盘的每一个键都由一个 8 位的二进制编码,所以 1 字节等于 8 比特.对数字而言,1 的二进制是 0000 ...
- js36---函数嵌套
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...
- 自绘listCtrl控件选中该行高亮(模拟windows)
CListCtrl的派生类CMyListCtrl的DrawItem()函数里添加代码 CDC *pDC = CDC::FromHandle(lpDrawItemStruct->hDC); if ...
- menu-普通menu弹出框样式
今天接触到了menu弹出框样式.主要就是在theme下进行调整.现在把接触到的知识点总结一下. 在theme中,跟menu有关的几个属性如下 <item name="panelBack ...
- java解压多目录Zip文件(解决中文乱码问题)--转载
原文地址:http://zhangyongbo.iteye.com/blog/1749439 import java.io.BufferedOutputStream; import java.io.F ...
- Leetcode-求两数之和
题目: 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,你不能重复利用这个数组中 ...
- 双向链表(自己写的c++类)
UVA还是上不去T T哭瞎了. 只好老老实实的研究上回买的书了. 写得有点长.好吧,我只是来复习C++类的. 特意用class 而不用struct写链表. 数据结构还没学...双向链表就当先预习了. ...
- 低成本开始互联网创业:探讨域名、服务器、CDN、邮箱等节流之道
互联网创业一直是个热门话题,对这个问题我也有不断的思考. 今天,探讨下如何低成本开始互联网创业. 背景 愿意冒险去创业的同志,大多是"屌丝"而非"高富帅",大多 ...
- WGS84与WGS84 Web Mercator
1. WGS84与WGS84 Web Mercator 1.1 关于WGS1984投影坐标系 UTM (Universal Transverse Mercator)坐标系是由美国军方在1947提出的. ...
- 设计模式--单例模式之Lock
1.为什么用Lock及关键知识 当我们使用线程的时候,效率最高的方式当然是异步,即个个线程同时运行,其间互不依赖和等待.当不同的线程都需要访问某个资源的时候,就需要同步机制了,也就是说当对同一个资源进 ...