#P12016. [NOISG 2025 Finals] Thumper

    ID: 11917 远端评测题 1000ms 1024MiB 尝试: 0 已通过: 0 难度: 6 上传者: 标签>树状数组2025NOISG(新加坡)

[NOISG 2025 Finals] Thumper

Description

Bunnyland 有广阔的田野,Bunnyland 矮兔(一种本地兔子物种)在其中自由活动。其中一个田野可以建模为一个 109×10910^9 \times 10^9 的网格单元。网格的行从北到南编号为 1110910^9,网格的列从西到东编号为 1110910^9。我们将网格中位于第 rr 行、第 cc 列的单元格称为单元格 (r,c)(r, c)

在这片田野中,有 nn 只兔子,编号从 11nn。第 ii 只兔子最初位于单元格 (r[i],c[i])(r[i], c[i])最初没有两只兔子位于同一个单元格

当兔子感到烦躁时,它们会抬起后腿并踢打地面,这一动作被称为震踏。这 nn 只兔子将执行一系列 mm 次震踏。在第 jj 秒开始时,编号为 t[j]t[j] 的兔子会进行震踏。当一只兔子震踏时,所有其他兔子都会远离震踏的兔子。

具体来说,当兔子 A 震踏时,兔子 B 将按照以下方式移动:

  • 如果 A 和 B 之间的行数小于列数,则 B 将在列方向上远离 A 两列。
  • 如果 A 和 B 之间的行数等于列数,则 B 将在列方向和行方向各远离 A 一格。
  • 如果 A 和 B 之间的行数大于列数,则 B 将在行方向上远离 A 两行。

可以证明,在震踏发生后,兔子的位置仍然是唯一的。

兔子 Benson 在退休后寻找它的同类,但由于震踏的发生,兔子们四散开来。请帮助 Benson 确定在所有震踏发生后 nn 只兔子的最终位置!

可以保证,在震踏序列过程中,兔子不会离开网格。你也可以假设,兔子在任何情况下都不会移动,除了震踏。

Input Format

你的程序必须从标准输入读取数据。

输入的第一行包含两个由空格分隔的整数 nnmm

接下来的 nn 行输入中,每行包含两个由空格分隔的整数。这些整数分别是 r[i]r[i]c[i]c[i],表示第 ii 只兔子的初始位置。

输入的最后一行包含 mm 个由空格分隔的整数 t[1],t[2],,t[m]t[1], t[2], \ldots, t[m]

Output Format

你的程序必须向标准输出打印结果。

输出应包含 nn 行。第 ii 行应包含两个由空格分隔的整数,表示所有震踏发生后,第 ii 只兔子所在的行和列。

2 1
1 1
2 2
1
1 1
3 3
13 1
7 7
3 7
4 4
4 10
5 6
6 4
6 8
8 7
8 10
9 3
9 5
9 9
10 6
1
7 7
1 7
3 3
3 11
3 6
6 2
5 9
10 7
8 12
9 1
10 4
10 10
12 6
3 2
1 10
1 20
1 30
1 3
1 8
1 20
1 32

Hint

子任务

对于所有测试用例,输入将满足以下约束条件:

  • 1n,m5000001 \leq n, m \leq 500\,000
  • 对于所有 1in1 \leq i \leq n,有 1r[i],c[i]1091 \leq r[i], c[i] \leq 10^9
  • 对于所有 1jm1 \leq j \leq m,有 1t[j]n1 \leq t[j] \leq n
  • 对于所有 iji \neq j,有 (ri,ci)(rj,cj)(r_i, c_i) \neq (r_j, c_j)
  • 可以保证,在震踏序列过程中,兔子不会离开网格。

你的程序将在满足以下特殊性质的输入数据上进行测试:

子任务 分数 特殊性质
00 样例
11 1818 n,m2000n, m \leq 2000
22 2121 r[i]=1r[i] = 1
33 3232 n2000n \leq 2000
44 1313 n100000n \leq 100\,000
55 1616

样例 1 解释

此测试用例适用于子任务 1,3,4,51, 3, 4, 5

兔子 11 处于单元格 (1,1)(1, 1),兔子 22 处于单元格 (2,2)(2, 2)

由于兔子 11 和兔子 22 之间的行数等于列数,因此当兔子 11 震踏时,兔子 22 会在东南方向各远离一格,最终到达单元格 (3,3)(3, 3)。震踏的兔子 11 位置保持不变。

样例 2 解释

此样例适用于子任务 1,3,4,51, 3, 4, 5

题目中的图示对应于此测试用例。蓝色箭头显示了当编号为 11 的兔子(位于单元格 (7,7)(7, 7))震踏时,其他兔子的移动方式。

样例 3 解释

此样例适用于所有子任务。