bzoj#P3290. Theresa与数据结构
Theresa与数据结构
题目描述
【题目背景】 Theresa是个爱思考的女孩…… 【问题描述】 这是个复杂的世界。人类社会,自然界,还有地球之外的银河…… 每一天日出日落,人来人往,步履匆匆。究竟是为什么呢?那支配着一切的至高无上的法则又是否存在呢?Theresa知道,这个问题并不是一朝一夕就可以解答的,只有在仔细、深入的观察和思考以后,才有可能将所有支离破碎的线索联系起来,从而隐约窥见真实的答案。 于是,Theresa经常思考生活中遇到的大大小小的问题。为什么港台出版的书籍里印刷的汉字她一个也不认识呢?为什么隔夜的白开水中富含一氧化二氢呢?为什么每年都有一段时间Gmail邮箱上不去呢?…… 为了更加系统、科学地分析这些问题,Theresa决定向你求助。 长话短说,Theresa想请你帮助她实现一个数据结构。这个数据结构的功能是在空间直角坐标系中维护一个点的集合,并支持以下三类操作: 1. ADD x y z 加入一个新的点,点的坐标为(x, y, z)。 2. QUERY x y z r 查询在正方体(x, y, z) - (x+r, y+r, z+r)内部的点的数目。 3. CANCEL 撤销最近的一次ADD操作。 其中x, y, z, r均为给出的整数。QUERY操作中,(x, y, z)为正方体的一个顶点的坐标,r为正方体的边长。在正方体边界上的点也算在正方体内部。 这个问题可能过于困难,所以Theresa并不强迫你实现一个高效的数据结构。然而,你必须对每一次QUERY操作给出正确的答案。
输入格式
第一行包含一个整数N,表示最初的点集有N个点。 接下来N行,每行包含三个整数x_{i}、y_{i}、z_{i},依次表示每个点的坐标。 第N+2行包含一个整数Q,表示将有Q次操作。 接下来Q行,每行表示一次操作,格式如题目描述。
输出格式
输出若干行,每行一个整数,依次表示每次查询操作的答案。
2
1 2 3
1 1 3
7
ADD 0 4 3
QUERY 0 0 0 4
ADD 1 1 5
QUERY 1 1 2 3
QUERY 0 2 2 1
CANCEL
QUERY 1 1 2 3
3
3
1
2
样例说明
第1次查询正方体(0, 0, 0) - (4, 4, 4),内部包含点(1, 2, 3),(1, 1, 3),(0, 4, 3)。
第2次查询正方体(1, 1, 2) - (4, 4, 5),内部包含点(1, 2, 3),(1, 1, 3),(1, 1, 5)。
第3次查询正方体(0, 2, 2) - (1, 3, 3),内部包含点(1, 2, 3)。
第4次查询正方体(1, 1, 2) - (4, 4, 5),内部包含点(1, 2, 3),(1, 1, 3)。
提示
对于100%的数据:1 ≤ N + Q ≤ 100 000, 0 ≤ x, y, z, r ≤ 107。r 为正整数。所有的CANCEL操作均为有效操作。不同的点的坐标可能重合。
题目来源
没有写明来源