Logo HelloWorld信息学奥赛题库

少儿编程

时间限制:1 s 空间限制:1024 MB

#4170. 「2017 山东二轮集训 Day4」增添

Statistics

题目描述

有一个长度为 $ n $ 的序列,要求支持三种操作:

  • 1 l r x 将 $ [l, r] $ 中的数增加 $ x $,保证 $ x \leq 10000 $;
  • 2 l r x 用 $ [l, l + x] $ 中的数对应替换 $ [r, r + x] $ 中的数;
  • 3 l r 求 $ [l, r] $ 中所有数的和。

输入格式

第一行两个正整数 $ n, m $ 表示序列长度和操作数。
第二行 $ n $ 个正整数表示初始序列中的数,保证每个数 $ \leq 10000 $。
接下来 $ m $ 行,每行三或四个整数,对应一个操作。
保证操作的区间合法且为 $ [1, n] $ 的子集。

输出格式

对每个操作三,单独输出一行表示答案。

样例

input

4 4
1 2 3 4
1 2 3 4
3 1 4
2 1 3 1
3 2 4

output

18
13

数据范围与提示

$ n \leq 100000, m \leq 100000 $