题目背景
“一个长度为l的数列ai,若相邻两数间的差ai−ai−1 (2≤i≤l)全部相同,则这个数列为等差数列。”火星特级数学老师jyy,正在给他的火星学生们上数学课。
题目描述
为了检验学生的掌握情况,jyy布置了一道习题:给定一个长度为N(1≤N≤100,000)的数列,初始时第i个数为vi(vi是整数,−100,000≤vi≤100,000),学生们要按照jyy的给出的操作步骤来改变数列中的某些项的值。操作步骤的具体形式为:A s t a b
(s,t,a,b均为整数,1≤s≤t≤N,−100,000≤a,b≤100,000),它表示,在序列的[s,t]区间上加上初值为a,步长为b的等差数列。即vi变为vi+a+b×(i−s)(对于s≤i≤t)。
在焦头烂额地计算之余,可怜的火星学生们还得随时回答jyy提出的问题。问题形式为:B s t
(s,t均为整数,1≤s≤t≤N),表示jyy询问当前序列的[s,t]区间最少能划分成几段,使得每一段都是等差数列。比如说1 2 3 5 7
最少能划分成2段,一段是1 2 3
,另一段是5 7
。询问是需要同学们计算出答案后,作为作业交上来的。
虽然操作数加问题数总共只有Q(1≤Q≤100,000)个,jyy还是觉得这个题很无聊很麻烦。于是他想让你帮他算一份标准答案。
输入格式
第1行:1个整数N,第2⋯N+1行:每行一个整数。第i+1行表示vi。
第N+2行:1个整数Q,第N+3⋯N+Q+2行:每行描述了一个操作或问题,格式如题中所述,不含引号。
输出格式
若干行,每行一个整数,表示对一个问题的回答。请按照输入中的顺序依次给出回答。
提示
样例说明:
原数列1 3 -1 -4 7
。经过操作之后,数列变为1 2 3 5 7
。如题中所述,最少能划分成2段。
数据规模:
对30%的数据,N,Q≤5000。
对100%的数据,1≤N,Q≤100,000。
其他数据范围见题面。