#P1533. 一个简单的整数问题2

一个简单的整数问题2

Description

给定长度为N的数列A,然后输入M行操作指令。
第一类指令形如“C l r d”,表示把数列中第l~r个数都加d。
第二类指令形如“Q l r ”,表示询问表示询问数列中第 l∼r个数的和。
对于每个询问,输出一个整数表示答案。

Input Format

第一行包含两个整数 N 和 M 。 

第二行包含 N 个整数 A[i] 。 

接下来 M 行表示 M 条指令,每条指令的格式如题目描述所示。

数据范围

1≤N,M≤105
,
|d|≤10000,
|A[i]|≤109

Output Format

对于每个询问,输出一个整数表示答案。 

每个答案占一行。

10 5
1 2 3 4 5 6 7 8 9 10
Q 4 4
Q 1 10
Q 2 4
C 3 6 3
Q 2 4
4
55
9
15

Source

树状数组 线段树 分块 模版