loj#P2228. 「AHOI2014」奇怪的计算器
「AHOI2014」奇怪的计算器
题目描述
JYY 有个奇怪的计算器,有一天这个计算器坏了,JYY 希望你能帮助他写一个程序来模拟这个计算器的运算。
JYY 的计算器可以执行 条预设好的指令。每次 JYY 向计算器输入一个正整数 ,计算器就会以 作为初始值,接着依次执行预设的 条指令,最后把 最终得出的结果返回给 JYY。 每一条指令可以是以下四种指令之一:(这里 表示一个正整数。)
+a
:表示将当前的结果加上 ;-a
:表示将当前的结果减去 ;*a
:表示将当前的结果乘以 ;@a
:表示将当前的结果加上 ( 是一开始 JYY 输入的数)。
计算器用于记录运算结果的变量的存储范围是有限的,所以每次运算结束之后会有计算结果溢出的问题。
JYY 的计算器中,存储每计算结果的变量只能存储 到 之间的正整数,如果一次指令执行过后,计算结果超过了 ,那么计算器就会自动把结果变成 ,然后再以 作为当前结果继续进行之后的计算。同理,如果运算结果小于 ,计算器也会把结果变成 ,再接着计算。
比如,假设计算器可以存储 到 之间的值,如果当前的计算结果是 ,那么在执行 +5
操作之后,存储结果的变量中的值将会是 。虽然 的实际结果是 ,但是由于 超过了存储范围的上界,所以结果就被自动更正成了上界的大小,也就是 。
JYY一共想在计算器上输入 个值,他想知道这 个值输入计算器之后,分别会得到什么结果呢?
输入格式
输入文件的第一行包含三个正整数,, 和 ;
接下来 行,每行一个指令,每个指令如题述,由一个字符和一个正整数组成,字符和正整数中间有一个空格隔开;
第 行包含一个整数 ,表示 JYY 希望输入的数的数量;
接下来 行每行一个正整数,第 个正整数 表示 JYY 在第 次输入的整数。
输出格式
输出 行每行一个正整数,第 行的整数表示输入 后,依次经过 个指令进行计算所得到的结果。
5 1 6
+ 5
- 3
* 2
- 7
@ 2
3
2
1
5
5
3
6
数据范围与提示
对于所有的数据,$1 \leq N,Q \leq 10^5,\ 1 \leq L \leq X_k \leq R \leq 10^9,\ 1 \leq a \leq 10^9$。