CF2185D.OutOfMemoryError

传统题 时间 2000 ms 内存 256 MiB 5 尝试 1 已通过 1 标签

OutOfMemoryError

题目描述

Bessie 有一个包含 nn 个整数的数组 a1,a2,,ana_1, a_2, \ldots, a_n。Bessie 对数组执行 mm 次操作。第 ii 次操作将 abia_{b_i} 变为 abi+cia_{b_i} + c_i

不幸的是,由于内存价格飞涨,Bessie 的计算机内存有限,只要数组中的任意一个元素大于 hh,她的计算机就会崩溃,并且整个数组会恢复到最初的状态。

所有操作执行完毕后,输出最终的数组 aa

输入格式

输入第一行包含一个整数 tt1t1041 \leq t \leq 10^4),表示测试用例的数量。

每个测试用例第一行包含三个整数 n,m,hn, m, h1n,m21051 \le n, m \le 2 \cdot 10^51h1091 \leq h \leq 10^9),分别表示数组 aa 的长度、执行的操作数,以及 Bessie 的计算机在崩溃前能存储的最大值。

第二行包含 nn 个整数 a1,a2,,ana_1, a_2, \ldots, a_n0aih0 \le a_i \le h),表示数组 aa

接下来的 mm 行,每行包含两个整数 bi,cib_i, c_i1bin1 \leq b_i \leq n0ci1090 \leq c_i \leq 10^9),表示 Bessie 对数组执行的操作。

保证所有测试用例中 nn 的总和与 mm 的总和均不超过 21052 \cdot 10^5

输出格式

对于每个测试用例,输出所有操作执行完毕后的数组 aa

说明/提示

对于第一个测试用例,数组 aa 的变化如下:

  • 开始前,a=[1,2,1]a = [1, 2, 1]
  • 执行第一次操作后,a=[5,2,1]a = [5, 2, 1]
  • 第二次操作后,a=[5,6,1]a = [5, 6, 1],但因为 6>h6 > h,计算机崩溃,a=[1,2,1]a = [1, 2, 1](恢复原值)。
  • 第三次操作后,a=[1,2,4]a = [1, 2, 4]
  • 第四次操作后,a=[1,2,4]a = [1, 2, 4]

对于第三个测试用例,每次操作都会造成计算机崩溃,所以最终 a=[1,0,0,0]a = [1, 0, 0, 0]

由 ChatGPT 5 翻译

样例

3
3 4 5
1 2 1
1 4
2 4
3 3
2 0
5 3 1
1 1 1 1 1
1 1
1 1
2 1
4 4 1
1 0 0 0
1 1
4 4
3 3
4 4
1 2 4 
1 1 1 1 1 
1 0 0 0 

在线编程 IDE

建议全屏模式获得最佳体验