[清华集训2012] 序列操作
题目背景
**滥用评测功能将被封号。**
题目描述
有一个长度为 $n$ 的序列,有三个操作:
1. `I a b c` 表示将 $[a,b]$ 这一段区间的元素集体增加 $c$;
2. `R a b`表示将 $[a,b]$ 区间内所有元素变成相反数;
3. `Q a b c` 表示询问 $[a,b]$ 这一段区间中选择 $c$ 个数相乘的所有方案的和 $\mod 19940417$ 的值。
输入输出格式
输入格式
第一行两个数 $n, q$ 表示序列长度和操作个数。
第二行 $n$ 个整数,表示序列。
接下来 $q$ 行每行输入一个操作 `I a b c` 或者 `R a b` 或者 `Q a b c`,意义如题目描述。
输出格式
对于每个询问,输出选出 $c$ 个数相乘的所有方案的和 $\mod 19940417$ 的值。
输入输出样例
输入样例 #1
5 5
1 2 3 4 5
I 2 3 1
Q 2 4 2
R 1 5
I 1 3 -1
Q 1 5 1
输出样例 #1
40
19940397
说明
**样例说明:**
做完第一个操作序列变为 `1 3 4 4 5`。
第一次询问结果为 $3 \times 4+3 \times 4+4 \times 4=40$。
做完 `R` 操作变成 `-1 -3 -4 -4 -5`。
做完 `I` 操作变为 `-2 -4 -5 -4 -5`。
第二次询问结果为 $-2-4-5-4-5=-20$。
**数据范围:**
对于 $100\%$ 的数据,$n \leq 50000, q \leq 50000$。初始序列的元素的绝对值 $\leq 10^9$,保证 $[a,b]$ 是一个合法区间,`I` 操作中 $|c| \leq 10^9$,`Q` 操作中 $1 \leq c \leq \min(b-a+1,20)$。