#P7497. 四方喝彩

四方喝彩

题目背景

念出他们的名字,让他们,再次回到舞台。

麦克要在月亮河马戏团表演全新的杂技节目了!

题目描述

麦克一共有 nn 个新节目,每个节目的惊险值为 aia_i

接下来麦克可以通过若干次操作来对每个节目的惊险值进行变换:

  • 麦克使用冰球,对于所有的 lirl\leq i\leq r,第 ii 个节目的惊险值会增加 xx

  • 麦克使用土球,对于所有的 lirl\leq i\leq r,第 ii 个节目的惊险值会乘以 xx

  • 麦克使用火球,对于所有的 lirl\leq i\leq r,第 ii 个节目的惊险值在接下来的 xx 个操作中不会受到冰球和土球的影响。火球效果不会被替换

当然观众对每个节目的惊险值也很好奇,所以你需要在操作过程中帮麦克回答对于所有 lirl\leq i\leq r,第 ii 个节目的惊险值之和。当然观众不希望惊险值过大,所以你需要将结果对 109+710^9+7 取模。


简要题意:

给你一个长度为 nn 的数组 aa,你需要支持如下几个操作:

  1. l r x:对所有 lirl\leq i\leq r,令 aia_i 增加 xx
  2. l r x:对所有 lirl\leq i\leq r,令 aia_i 乘上 xx
  3. l r x:对所有 lirl\leq i\leq r,在接下来的 xx 个操作内,aia_i 将会被封锁,不会受到操作 1 和操作 2 的影响(设本次操作为第 kk 次操作,则第 k+1,k+2,,k+xk+1,k+2,\cdots,k+x 次操作中的所有操作 1和操作 2 不会对区间 [l,r]\left[l,r\right] 产生影响)。已有的封锁效果不会被替换(即假设第 33 次有一个操作 3 对某个位置进行封锁,封锁时间为 55,第 55 次操作同样对这个位置进行封锁,封锁时间为 22 那么实际上这个位置在第 44 次操作到第 88 次操作的时间内都会被封锁)(感性理解就是后面时间短的封锁不会使前面时间长的封锁失效)。
  4. l r:询问 lirai\sum\limits_{l\leq i\leq r}a_i,对 109+710^9+7 取模。

输入格式

第一行有两个正整数 n,mn,m,分别表示数组长度和操作数。

第二行会有 nn 个整数 aia_i,表示数组 aa

接下来 mm 行,每行有三个整数 opt,l,ropt,l,r 表示操作编号以及这次操作的 l,rl,r,如果 opt3opt\leq 3,那么还会有一个整数 xx,表示这次操作的 xx

输出格式

对于所有的操作 4,一行一个整数表示结果,对 109+710^9+7 取模。

5 5
1 5 4 3 6
1 2 4 3
3 1 2 2
4 2 5
2 2 3 4
4 1 3
27
37
10 12
4 2 1 5 10 3 2 4 6 7
2 3 7 4
1 2 9 5
3 2 4 5
3 4 7 2
4 3 9
1 1 8 2
2 4 5 2
3 6 8 2
4 2 3
1 2 10 6
2 7 9 3
4 1 10
129
16
314

提示

样例一解释

一开始数组为 {1,5,4,3,6}\{1,5,4,3,6\}

  • 执行第 11 次操作,此时数组变为 {1,8,7,6,6}\{1,8,7,6,6\}
  • 执行第 22 次操作,此时数组不变。
  • 执行第 33 次操作,询问结果为 2727
  • 执行第 44 次操作,因为此时 a2a_2 在第 22 次操作中被封锁还未解除,所以这次操作只对 a3a_3 产生影响,数组变为 {1,8,28,6,6}\{1,8,28,6,6\}
  • 执行第 55 次操作,询问结果为 3737

数据范围

本题采用捆绑测试

  • Subtask 1 ( 25%25\% ):n,m2×103n,m\leq2\times10^3
  • Subtask 2 ( 8%8\% ):没有操作 3。
  • Subtask 3 ( 17%17\% ):对于所有操作 4,保证 l=rl=r
  • Subtask 4 ( 50%50\% ):无特殊限制。

对于所有数据,$1\leq n,m\leq 2\times 10^5,0\leq a_i<10^9+7,1\leq l\leq r\leq n$,对于所有操作 1 和操作 2,保证 0x<109+70\leq x<10^9+7,对于所有操作 3,设其为第 kk 次操作,保证 0xmk0\leq x\leq m-k