序列维护 --线段树 3【模板】
提交数: 81, 通过率: 43.21%, 平均分: 55.93
题目描述:
如题,已知一个数列,你需要进行下面三种操作:
1.将某区间每一个数乘上x;
2.将某区间每一个数加上x;
3.求出某区间每一个数的和,由于结果可能很大,你只需要输出这个数模P的值。
输入格式:
第一行包含两个整数N、P,分别表示该数列数字的个数、模数。
第二行包含N个用空格分隔的整数,其中第i个数字表示数列第i项的初始值。
第三个一个整数M,表示操作的次数。
接下来M行每行包含3或4个整数,表示一个操作,具体如下:
操作1: 格式:1 x y k 含义:将区间[x,y]内每个数乘上k
操作2: 格式:2 x y k 含义:将区间[x,y]内每个数加上k
操作3: 格式:3 x y 含义:输出区间[x,y]内每个数的和对P取模所得的结果
输出格式:
输出包含若干行整数,即为所有操作3的输出结果。
样例输入:
7 43 1 2 3 4 5 6 7 5 1 2 5 5 3 2 4 2 3 7 9 3 1 3 3 4 7
样例输出:
2 35 8
提示:
样例解释:
初始时数列为{1, 2, 3, 4, 5, 6, 7}
经过第一次操作后,数列为{1, 10, 15, 20, 25, 6, 7}
对第二次操作,和为10+15+20 = 45, 模43的结果是2。
经过第三次操作后,数列为{1, 10, 24, 29, 34, 15, 16}
对第四次操作,和为1+10+24 = 35, 模43的结果是35。
对第五次操作,和为29+34+15+16 = 94 , 模43的结果是8。
对于30%的数据:N<=1000,M<=1000;
对于100%的数据:N<=100000,M<=100000。
时间限制: 1000ms
空间限制: 128MB
来源: Ahoi2009