#P50707. [APIO 2018] Circle selection

[APIO 2018] Circle selection

题目描述

在平面上,有 nn 个圆,记为 c1,c2,,cnc_1, c_2, \ldots, c_n 。我们尝试对这些圆运行这个算法:

  1. 找到这些圆中半径最大的。如果有多个半径最大的圆,选择编号最小的。记为 cic_i
  2. 删除 cic_i 及与其有交集的所有圆。两个圆有交集的含义是,平面上存在某一点,同时处于这两个圆的圆周上或圆内。
  3. 重复上面两个步骤直到所有的圆都被删除。

circle.png

cic_i 被删除时,若循环中第一步选择的圆是 cjc_j ,我们说 cic_icjc_j 删除。对于每个圆,求出它是被哪一个圆删除的。

输入格式

第一行包含一个整数 nn ,表示开始时平面上圆的数量 (1n31051 \le n \le 3 \cdot 10^5)。

接下来 nn 行,每行包含三个整数 xi,yi,rix_i, y_i, r_i 依次描述圆 cic_i 圆心的 xx 坐标、yy 坐标和它的半径 (109xi,yi109-10^9 \le x_i, y_i\le 10^9, 1ri1091\le r_i\le 10^9)。

输出格式

输出一行,包含 nn 个整数 a1,a2,...ana_1, a_2, ... a_n ,其中 aia_i 表示圆 cic_i 是被圆 caic_{a_i} 删除的。

样例

11
9 9 2
13 2 1
11 8 2
3 3 2
3 12 1
12 14 1
9 8 5
2 8 2
5 2 1
14 4 2
14 14 1
7 2 7 4 5 6 7 7 4 7 6

题目描述中的图片对应了样例中的情形。

数据范围与提示

子任务 1(7 分):n5000n \le 5000

子任务 2(12 分):n3105n \le 3 \cdot 10^5, 对于所有的圆 yi=0y_i=0

子任务 3(15 分):n3105n \le 3 \cdot 10^5, 每个圆最多和一个其他圆有交集。

子任务 4(23 分):n3105n \le 3 \cdot 10^5, 所有的圆半径相同。

子任务 5(30 分):n105n \le 10^5

子任务 6(13 分):n3105n \le 3 \cdot 10^5