#P1559. [算法竞赛进阶指南]A Simple Problem with Integers

[算法竞赛进阶指南]A Simple Problem with Integers

Description

[poj 3468]

给定一个长度为N的数列A,以及M条指令,每条指令可能是以下两种之一:

1、“C l r d”,表示把 A[l],A[l+1],…,A[r] 都加上 d。

2、“Q l r”,表示询问 数列中第 l~r 个数的和。

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

Input Format

第一行两个整数N,M。

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

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

数据范围

1N,M1051≤N,M≤10^5,

|d|≤10000,

|A[i]|≤1000000000

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

树状数组 线段树