题目描述
给出一个长度为 n 的数组 Ai,由 1 到 n 标号 , 你需要维护 m 个操作。
操作分为三种,输入格式为:
- l r d,将数组中下标 l 到 r 的位置都加上 d,即对于 l≤i≤r,执行 Ai=Ai+d。
- l1 r1 l2 r2,将数组中下标为 l1 到 r1 的位置,赋值成 l2 到 r2的值,保证 r1−l1=r2−l2。换句话说先对 0≤i≤r2−l2 执行 Bi=A(l2+i),再对 0≤i≤r1−l1 执行 A(l1+i)=Bi,其中 Bi 为一个临时数组。
- l r,求数组中下标 l 到 r 的位置的和,即求出∑i=1rAi 。
输入描述
第一行一个整数 Case,表示测试点编号,其中 Case=0 表示该点为样例。
第二行包含两个整数 n,m。保证 1≤n,m≤105。
第三行包含 n 个整数 Ai,表示这个数组的初值。保证 0≤Ai≤105。
接下来 m 每行描述一个操作,格式如问题描述所示。
其中,$0≤d≤10^5,1≤l≤r≤n,1≤l_1≤r_1≤n1≤l_2≤r_2≤n,r_1−l_1=r_2−l_2$。
输出描述:
对于每次 3 操作输出一行一个数,表示求和的结果。
0
5 6
1 2 3 4 5
2 1 3 3 5
3 3 5
1 2 4 2
3 3 5
2 1 3 3 5
3 1 5
14
18
29