Farmer John 正在尝试雇佣承包商来帮助他重新安排农场,但到目前为止,所有承包商在看到 FJ 希望他们遵循的复杂指令序列后都辞职了。FJ 不得不自己完成这个项目,他意识到自己可能把项目搞得比必要的还要复杂。请帮助他按照指令完成农场的升级。
FJ 的农场由一排N 个田地组成,编号为1…N。每个田地里可以有任意数量的干草堆。Farmer John 的指令包含三种类型的条目:
给定一个连续的田地区间,向每个田地添加一个新的干草堆。
给定一个连续的田地区间,确定该区间内田地中干草堆的最小数量。
给定一个连续的田地区间,计算该区间内干草堆的总数。
第一行包含两个正整数,N(1≤N≤200,000)和 1≤Q≤100,000)。
第二行包含 N 个非负整数,每个整数最多为 100,000,表示每个田地中初始的干草堆数量。
接下来的 Q 行每行包含一个大写字母,可能是 M、P 或 S,后跟两个正整数 A 和 B(1≤A≤B≤N),或者三个正整数 A、B 和 C(1≤C≤100,000)。 只有当大写字母是 P 时,才会有三个正整数。
如果字母是 M,输出从 A…B 的田地区间内干草堆的最小数量。
如果字母是 P,向从 A…B 的田地区间内的每个田地添加 C 个新的干草堆。
如果字母是 S,输出从 A…B 的田地区间内干草堆的总数。
对于 FJ 指令中的每一个 'M' 或 'S' 条目,输出一行相应的结果。
4 5 3 1 2 4 M 3 4 S 1 3 P 2 3 1 M 3 4 S 1 3
2 6 3 8