扶苏的问题

题目描述

给定一个长度为 $n$ 的序列 $a$,要求支持如下三个操作: 1. 给定区间 $[l, r]$,将区间内每个数都修改为 $x$。 2. 给定区间 $[l, r]$,将区间内每个数都加上 $x$。 3. 给定区间 $[l, r]$,求区间内的最大值。

输入输出格式

输入格式


第一行是两个整数,依次表示序列的长度 $n$ 和操作的个数 $q$。 第二行有 $n$ 个整数,第 $i$ 个整数表示序列中的第 $i$ 个数 $a_i$。 接下来 $q$ 行,每行表示一个操作。每行首先有一个整数 $op$,表示操作的类型。 - 若 $op = 1$,则接下来有三个整数 $l, r, x$,表示将区间 $[l, r]$ 内的每个数都修改为 $x$。 - 若 $op = 2$,则接下来有三个整数 $l, r, x$,表示将区间 $[l, r]$ 内的每个数都加上 $x$。 - 若 $op = 3$,则接下来有两个整数 $l, r$,表示查询区间 $[l, r]$ 内的最大值。

输出格式


对于每个 $op = 3$ 的操作,输出一行一个整数表示答案。

输入输出样例

输入样例 #1

6 6
1 1 4 5 1 4
1 1 2 6
2 3 4 2
3 1 4
3 2 3
1 1 6 -1
3 1 6

输出样例 #1

7
6
-1

输入样例 #2

4 4
10 4 -3 -7
1 1 3 0
2 3 4 -4
1 2 4 -9
3 1 4

输出样例 #2

0

说明

### 数据规模与约定 - 对于 $10\%$ 的数据,$n = q = 1$。 - 对于 $40\%$ 的数据,$n, q \leq 10^3$。 - 对于 $50\%$ 的数据,$0 \leq a_i, x \leq 10^4$。 - 对于 $60\%$ 的数据,$op \neq 1$。 - 对于 $90\%$ 的数据,$n, q \leq 10^5$。 - 对于 $100\%$ 的数据,$1 \leq n, q \leq 10^6$,$1 \leq l, r \leq n$,$op \in \{1, 2, 3\}$,$|a_i|, |x| \leq 10^9$。 ### 提示 请注意大量数据读入对程序效率造成的影响。