#P8640. [蓝桥杯 2016 国 A] 圆圈舞

[蓝桥杯 2016 国 A] 圆圈舞

题目描述

春天温暖的阳光照耀着大地,正是草原上的小动物们最快乐的时候。小动物们在草原上开了一个舞会,欢度这美好的时光。

舞会上最重要的一个环节就是跳圆舞曲,nn 只小动物手拉手围成一大圈,随着音乐跳起来。在跳的过程中,小动物们可能会变换队形。它们的变换方式是动物 A 松开自己右手,动物 B 松开自己的左手,动物 A 和 B 手拉到一起,而它们对应的松开的手(如果有的话)也拉到一起。

例如,假设有 1010 只小动物,按顺序围成一圈,动物 11 的右手拉着动物 22 的左手,动物 22 的右手拉着动物 33 的左手,依次类推,最后动物 1010 的右手拉着动物 11 的左手。如果通过动物 2288 变换队形,则动物 22 的右手拉着动物 88 的左手,而对应的动物 33 的左手拉着动物 77 的右手,这样形成了 1-2-8-9-103-4-5-6-7 两个圈。如果此时通过动物 2266 变换队形,则将形成 1-2-6-7-3-4-5-8-9-10 一个大圈。注意,如果此时通过动物 1122 变换队形,那么队形不会改变,因为动物 11 的右手和动物 22 的左手松开后又拉到一起了。

在跳舞的过程中,每个动物 ii 都有一个欢乐值 HiH_i 和一个感动值 FiF_i

如果两个动物在一个圈中,欢乐值会彼此影响,产生欢乐能量。如果两个动物 i,j(ij)i, j(i\neq j) 在同一个大小为 tt 的圈中,而动物 ii 在动物 jj 右手的第 pp 个位置(动物 jj 右手的第 11 个位置就是动物 jj 右手所拉着的动物,而第 22 个位置就是右手第 11 个位置的动物右手拉着的动物,依次类推),则产生的欢乐能量为 (tp)×Hj×Fi(t-p)\times H_j\times F_i。在跳舞的过程中,动物们的欢乐值和感动值有可能发生变化。

圆舞曲开始的时候,所有的动物按编号顺序围成一个圈,动物 nn 右手的第 ii 个位置正好是动物 ii。现在已知小动物们变换队形的过程和欢乐值、感动值变化的过程,求每次变换后所有动物所产生的欢迎能量之和。

输入格式

输入的第一行包含一个整数 nn,表示动物的数量。

接下来 nn 行,每行两个用空格分隔的整数 HiH_iFiF_i,按编号顺序给出每只动物的欢乐值和感动值。 接下来一行包含一个整数 mm,表示队形、欢乐值、感动值的变化次数。

接下来 mm 行,每行三个用空格分隔的整数 kkppqq,当 k=1k=1 时,表示小动物们通过动物 pp 和动物 qq 变换了队形,当 k=2k=2 时,表示动物 pp 的欢乐值变为 qq,当 k=3k=3 时,表示动物 pp 的感动值变为了 qq

输出格式

输出 mm 行,每行一个整数,表示每次变化后所有动物产生的能量之和。

答案可能很大,你需要计算答案除以 10000000071000000007(即 109+710^9+7) 的余数。

10
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
1 1
9
1 2 8
1 2 6
2 8 10
3 5 10
1 1 2
1 2 1
2 5 5
1 4 8
1 4 5
100
450
855
1341
1341
811
923
338
923

提示

对于 20%20\% 的数据,2n,m1002\le n,m\le100

对于 30%30\% 的数据,2n,m10002\le n,m\le1000

另有 20%20\% 的数据,只有 k=1k=1 的操作且 HiH_iFiF_i 均为 11

另有 20%20\% 的数据,只有 k=1k=122 的操作且 FiF_i 均为 11

对于 100%100\% 的数据,2n,m1052\le n,m\le10^50Hi,Fi1090\le H_i,F_i\le10^91k31\le k\le3k=1k=11p,qn1\le p,q\le npqp\neq qk=2k=2331pn1\le p\le n0q1090\le q\le10^9