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

提高+/省选-

通过率:0%

时间限制:1.00s

内存限制:1024MB

题目描述

有一个长度为 $ 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] $ 的子集。

输出格式

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

输入输出样例

  • 输入#1

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

    输出#1

    18
    13

说明/提示

$ n \leq 100000, m \leq 100000 $

首页