luogu#P4243. [JSOI2009] 等差数列

[JSOI2009] 等差数列

题目背景

“一个长度为ll的数列aia_i,若相邻两数间的差aiai1 (2il)a_i - a_{i-1} \ (2 \leq i \leq l)全部相同,则这个数列为等差数列。”火星特级数学老师jyy,正在给他的火星学生们上数学课。

题目描述

为了检验学生的掌握情况,jyy布置了一道习题:给定一个长度为NN1N100,0001 \leq N \leq 100,000)的数列,初始时第ii个数为viv_iviv_i是整数,100,000vi100,000-100,000 \leq v_i \leq 100,000),学生们要按照jyy的给出的操作步骤来改变数列中的某些项的值。操作步骤的具体形式为:A s t a bs,t,a,bs, t, a, b均为整数,1stN1 \leq s \leq t \leq N100,000a,b100,000-100,000 \leq a, b \leq 100,000),它表示,在序列的[s,t][s, t]区间上加上初值为aa,步长为bb的等差数列。即viv_i变为vi+a+b×(is)v_i + a + b \times (i - s)(对于sits \leq i \leq t)。

在焦头烂额地计算之余,可怜的火星学生们还得随时回答jyy提出的问题。问题形式为:B s ts,ts, t均为整数,1stN1 \leq s \leq t \leq N),表示jyy询问当前序列的[s,t][s, t]区间最少能划分成几段,使得每一段都是等差数列。比如说1 2 3 5 7最少能划分成22段,一段是1 2 3,另一段是5 7。询问是需要同学们计算出答案后,作为作业交上来的。

虽然操作数加问题数总共只有QQ1Q100,0001 \leq Q \leq 100,000)个,jyy还是觉得这个题很无聊很麻烦。于是他想让你帮他算一份标准答案。

输入格式

11行:11个整数NN,第2N+12 \cdots N + 1行:每行一个整数。第i+1i + 1行表示viv_i

N+2N + 2行:11个整数QQ,第N+3N+Q+2N + 3 \cdots N + Q + 2行:每行描述了一个操作或问题,格式如题中所述,不含引号。

输出格式

若干行,每行一个整数,表示对一个问题的回答。请按照输入中的顺序依次给出回答。

5
1
3
-1
-4
7
2
A 2 4 -1 5
B 1 5
2

提示

样例说明:

原数列1 3 -1 -4 7。经过操作之后,数列变为1 2 3 5 7。如题中所述,最少能划分成22段。

数据规模:

30%30\%的数据,N,Q5000N, Q \leq 5000

100%100\%的数据,1N,Q100,0001 \leq N, Q \leq 100,000

其他数据范围见题面。