【模板】线段树 3
该比赛已结束,您无法在比赛模式下递交该题目。您可以点击“在题库中打开”以普通模式查看和递交本题。
题目描述
如题,已知一个数列,你需要进行下面两种操作:
- 修改某个数字。
- 求出某区间中所有数字两两乘积的和。
- 求出某区间中所有相邻数字的乘积和。
注意
- 两两乘积的和指:,比如区间的数字是,则答案为$a\times b + a\times c + a\times d+b\times c+b\times d + c\times d$。
- 相邻数字乘积和指::比如区间的数字是,则答案是。
查询操作均对取余。
输入格式
第一行包含两个整数 ,分别表示该数列数字的个数和操作的总个数。
第二行包含 个用空格分隔的整数,其中第 个数字表示数列第 项的初始值。
接下来 行每行包含 个整数,表示一个操作,具体如下:
1 x k
:将区间 的数字变成 。2 x y
:输出区间 中所有数字两两乘积的和。3 x y
:输出区间 中所有相邻数字的和。
保证区间长度大于等于2.
输出格式
输出包含若干行整数,即为所有操作 2,3 的结果。
样例 #1
5 4
1 5 4 2 3
3 1 3
1 2 2
3 1 3
2 3 5
25
10
26
样例输入2、3请查看右侧文件
提示
对于 的数据: