CF2185D OutOfMemoryError

题目描述

Bessie 有一个包含 $n$ 个整数的数组 $a_1, a_2, \ldots, a_n$。Bessie 对数组执行 $m$ 次操作。第 $i$ 次操作将 $a_{b_i}$ 变为 $a_{b_i} + c_i$。 不幸的是,由于内存价格飞涨,Bessie 的计算机内存有限,只要数组中的任意一个元素大于 $h$,她的计算机就会崩溃,并且整个数组会恢复到最初的状态。 所有操作执行完毕后,输出最终的数组 $a$。

输入格式

输入第一行包含一个整数 $t$($1 \leq t \leq 10^4$),表示测试用例的数量。 每个测试用例第一行包含三个整数 $n, m, h$($1 \le n, m \le 2 \cdot 10^5$,$1 \leq h \leq 10^9$),分别表示数组 $a$ 的长度、执行的操作数,以及 Bessie 的计算机在崩溃前能存储的最大值。 第二行包含 $n$ 个整数 $a_1, a_2, \ldots, a_n$($0 \le a_i \le h$),表示数组 $a$。 接下来的 $m$ 行,每行包含两个整数 $b_i, c_i$($1 \leq b_i \leq n$,$0 \leq c_i \leq 10^9$),表示 Bessie 对数组执行的操作。 保证所有测试用例中 $n$ 的总和与 $m$ 的总和均不超过 $2 \cdot 10^5$。

输出格式

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

说明/提示

对于第一个测试用例,数组 $a$ 的变化如下: - 开始前,$a = [1, 2, 1]$。 - 执行第一次操作后,$a = [5, 2, 1]$。 - 第二次操作后,$a = [5, 6, 1]$,但因为 $6 > h$,计算机崩溃,$a = [1, 2, 1]$(恢复原值)。 - 第三次操作后,$a = [1, 2, 4]$。 - 第四次操作后,$a = [1, 2, 4]$。 对于第三个测试用例,每次操作都会造成计算机崩溃,所以最终 $a = [1, 0, 0, 0]$。 由 ChatGPT 5 翻译