#1251. 序列终结者

序列终结者

题目背景

网上有许多题,就是给定一个序列,要你支持几种操作: A,B,C,DA,B,C,D 。一看另一道题,又是一个序列。要支持几种操作: D,C,B,AD,C,B,A 。尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技术含量……

这样,我也出一道题,我出这一道的目的是为了让大家以后做这种题目有一个“库”可以依靠,没有什么其他的意思。这道题目,就叫序列终结者吧。

题目描述

给定一个长度为 NN 的序列,每个序列的元素是一个整数(废话)。

要支持以下三种操作:

  1. [L,R][L,R] 这个区间内的所有数加上 VV
  2. [L,R][L,R] 这个区间翻转,比如 1 2 3 41 \ 2 \ 3 \ 4 变成 4 3 2 14 \ 3 \ 2 \ 1
  3. [L,R][L,R] 这个区间中的最大值。最开始所有元素都是 00

输入格式

第一行两个整数 N,MN,MMM 为操作个数。

以下 MM 行,每行最多四个整数,依次为 K,L,R,VK,L,R,V

KK 表示是第几种操作,如果不是第 11 种操作则 KK 后面只有两个数。

输出格式

对于每个第 33 种操作,给出正确的回答。

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

数据范围

N5×104,M105N \leq 5 \times 10^4,M \leq 10^5