#P16057. [CSPro 31] 阴阳龙

[CSPro 31] 阴阳龙

题目背景

洛谷的测试数据仅供民间交流使用,非官方测试数据。官方评测链接:https://www.cspro.org/

题目描述

西西艾弗岛的下方是一个庞大的遗迹群,神兽“阴阳龙”栖居在这个遗迹群中。

为了得到这件宝物,西西艾弗遗迹探索有限公司(以下简称“公司”)派遣了 pp 名员工前往遗迹群,这些员工依次编号为 11pp

遗迹可以视为一个大小为 n×mn \times m 的网格,左下角坐标 (1,1)(1, 1),右上角坐标 (n,m)(n, m)。初始时,第 ii 名员工所在的位置是 (xi,yi)(x_i, y_i)。保证所有员工初始所在的位置两两不同。

作为神兽,阴阳龙有着特殊之处。当其在 p=(u,v)\mathbf{p} = (u, v) 位置以强度 t[1,7]t \in [1, 7] 现身时,会导致遗迹群的环境发生阴和阳的转变,从而导致在遗迹中的人的位置发生变化。

具体来说,阴阳龙首先观察右、右上、上、左上、左、左下、下和右下这八个方向,并在这八个方向找到和阴阳龙“距离”最近的员工(不包括 p\mathbf{p})的“距离”。其中,垂直和水平方向的“距离”是指员工和阴阳龙连线的长度;斜线方向的“距离”是指员工和阴阳龙连线在水平方向上投影的长度。设想从阴阳龙的位置同时出发,分别向这 88 个方向前进,每一单位时间运动 11 个“距离”。如果在某一时刻,在某一方向刚好遇到一位员工,则此时前进的距离即被记为 kk;否则,如果在某一时刻,在某一方向上刚好到达遗迹的边界,但是在此之前任何方向上都没有遇到员工,则令 k=0k = 0。形式化描述上述确定 kk 的方法是:

d0\mathbf{d}_0d7\mathbf{d}_7 依次为向量 $(1, 0), (1, 1), (0, 1), (-1, 1), (-1, 0), (-1, -1), (0, -1), (1, -1)$,令:

$$\begin{aligned} K_1 &= \{ k \in \mathbb{N}^+ \mid \exists i \in [0, 7], j \in [1, p], \text{s.t. } (x_j, y_j) = \mathbf{p} + k\mathbf{d}_i \} \\ K_2 &= \{ k \in \mathbb{N}^+ \mid \forall i \in [0, 7], (\mathbf{p} + k\mathbf{d}_i) \in [1, n] \times [1, m] \} \end{aligned}$$

其中:

  • (xi,yi)(x_i, y_i) 为第 ii 名员工在此次阴阳龙现身前的位置(这个位置可能和其初始位置不同,但为了方便起见,我们使用同一个记号);
  • K1K_1 为所有员工到阴阳龙距离组成的集合;
  • K2K_2 为从阴阳龙出发直至在某一方向抵达边界所包括全部的距离组成的集合。

K=K1K2=K = K_1 \bigcap K_2 = \emptyset,则令 k=0k = 0;否则令 k=minK>0k = \min K > 0

例如,参考下图中的例子,其中左下角为 (1,1)(1, 1),右上角为 (7,7)(7, 7),共有 88 名员工,位置如图。

p=(4,4)\mathbf{p} = (4, 4),那么员工 11 刚好在阴阳龙所在位置,不计入;员工 33 不在阴阳龙的 88 个方向上,不计入;员工 22445566 与阴阳龙“距离”是 22;员工 778899 与阴阳龙“距离”是 33,因此有 K1={2,3}K_1 = \{2, 3\}。由于与阴阳龙“距离”为 33 就到达了遗迹的边界,所以有 K2={1,2,3}K_2 = \{1, 2, 3\}。因此 k=2k = 2

p=(2,2)\mathbf{p} = (2, 2),那么员工 2233778899 都不在阴阳龙的 88 个方向上,不计入;员工 1166 与阴阳龙的“距离”是 22;员工 4455 与阴阳龙的“距离”是 44,因此有 K1={2,4}K_1 = \{2, 4\}。由于与阴阳龙“距离”为 11 时,就在向下、向左、向左下三个方向上到达了遗迹的边界,所以有 K2={1}K_2 = \{1\}。因此 k=0k = 0

:::align{center} :::

如果 k>0k > 0,则将八个方向上的距离为 kk 的位置上的员工以 p\mathbf{p} 为中心逆时针旋转 tt 倍的八分之一个圆周的角度。形式化地:

  • k=0k = 0,则什么也不会发生。
  • 否则,i[0,7]\forall i \in [0, 7],若 p+kdi\mathbf{p} + k\mathbf{d}_i 位置上有员工,那么该员工会被移动到 p+kd(i+t)mod8\mathbf{p} + k\mathbf{d}_{(i+t) \bmod 8}

易知在所有员工移动结束后,每个位置上仍至多有一个员工。例如,在上图所示的例子中取 p=(4,4),t=1\mathbf{p} = (4, 4), t = 1,则变化后各员工所在位置如下图所示。

:::align{center} :::

在全部员工进入遗迹群后,西西艾弗遗迹探索有限公司总共探测到 qq 次阴阳龙的现身。很不幸的是,由于来自东方神秘力量的干扰,这 qq 次阴阳龙的现身后,西西艾弗遗迹探索有限公司失去了所有员工的位置信息,因此他希望你能帮他计算出所有员工的位置。

输入格式

从标准输入读入数据。

第一行四个正整数 n,m,p,qn, m, p, q

接下来 pp 行,第 ii 行两个正整数 (xi,yi)(x_i, y_i) 表示第 ii 名员工的初始位置。

保证所有员工初始所在的位置两两不同。

接下来 qq 行,第 ii 行三个正整数 ui,vi,tiu_i, v_i, t_i 表示西西艾弗遗迹探索有限公司探测到的第 ii 次阴阳龙现身的位置和强度。

输出格式

输出到标准输出。

为了减少输出量,设 qq 次阴阳龙的现身后所有员工的位置为 (x1,y1),,(xp,yp)(x_1, y_1), \dots, (x_p, y_p),则你只需要输出:

i=1pi×xi+yi\bigoplus_{i=1}^{p} i \times x_i + y_i

其中 \bigoplus 表示按位异或,即 C/C++ 中的 ^ 运算符。

3 3 9 1
1 1
1 2
1 3
2 1
2 2
2 3
3 1
3 2
3 3
2 2 1
20

提示

样例 1 解释

阴阳龙现身前,每个员工所在的位置如下:

3 6 9
2 5 8
1 4 7

阴阳龙现身一次后,每个员工所在位置如下:

6 9 8
3 5 7
2 1 4

数据范围

子任务编号 nn \le mm \le pp \le qq \le 子任务分值
1 10310^3 10510^5 40
2 10910^9 10310^3 15
3 10510^5 25
4 10910^9 ^ 20

对于全部数据:

$1 \le n, m \le 10^9, 1 \le p, q \le 1 \times 10^5, 1 \le x_i, u \le n, 1 \le y_i, v \le m, 1 \le t_i \le 7$。

保证所有员工初始所在的位置两两不同。