CF706D Vasiliy's Multiset
Description
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:
1. "+ x" — add integer $ x $ to multiset $ A $ .
2. "- 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.
3. "? x" — you are given integer $ x $ and need to compute the value data:image/s3,"s3://crabby-images/84adf/84adf82826cdf57e7f5bce9b24075b9aac9458f1" alt="", 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.
Input Format
N/A
Output Format
N/A
Explanation/Hint
After first five operations multiset $ A $ contains integers $ 0 $ , $ 8 $ , $ 9 $ , $ 11 $ , $ 6 $ and $ 1 $ .
The answer for the sixth query is integer data:image/s3,"s3://crabby-images/af7d2/af7d270c49f2efdb2517bcb687f9118249549ac7" alt="" — maximum among integers data:image/s3,"s3://crabby-images/a4468/a4468d0c3248500e1fb5317befa6ca58b4fe0667" alt="", data:image/s3,"s3://crabby-images/213c2/213c2b2b04211df71ff5427ce860d9b2f594ad25" alt="", data:image/s3,"s3://crabby-images/2501e/2501ed5470866d5b83797246d1b73d0bed481d1c" alt="", data:image/s3,"s3://crabby-images/d9d3d/d9d3d3aeccac1320be987c26b5947d7f4185aef0" alt="" and data:image/s3,"s3://crabby-images/33d11/33d11b81ecdf40144355003312291c15a9b7e66f" alt="".