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