OI Problems   关于

#7n2tvz. 项链工厂

时间限制:4 s       空间限制:125 MiB       标签: 数据结构 线段树 NOI 2007 

算法难度等级:4       思维难度等级:5       实现难度等级:6


本题来源于:NOI 2007

题目背景

T 公司是一家专门生产彩色珠子项链的公司,其生产的项链设计新颖、款式多样、价格适中,广受青年人的喜爱。

最近 T 公司打算推出一款项链自助生产系统,使用该系统顾客可以自行设计心目中的美丽项链。该项链自助生产系统包括硬件系统与软件系统,软件系统与用户进行交互并控制硬件系统,硬件系统接受软件系统的命令生产指定的项链。该系统的硬件系统已经完成,而软件系统尚未开发,T 公司的人找到了正在参加全国信息学竞赛的你,你能帮助 T 公司编写一个软件模拟系统吗?

题目描述

一条项链包含 NN 个珠子,每个珠子的颜色是 1,2,,c1,2,\cdots,c 中的一种。项链

被固定在一个平板上,平板的某个位置被标记位置 11 ,按顺时针方向其他位置被记为 2,3,…,N。

你将要编写的软件系统应支持如下命令:

输入格式

输入文件第一行包含两个整数 N,cN, c,分别表示项链包含的珠子数目以及颜色数目。

第二行包含 NN 个整数,x1,x2,,xnx_ 1, x_ 2,\cdots, x_ n,表示从位置 11 到位置 NN 的珠子的颜色,1xic1 \le x_i \le c

第三行包含一个整数 QQ,表示命令数目。

接下来的 QQ 行每行一条命令,如上文所述。

输出格式

对于每一个 CCS 命令,应输出一个整数代表相应的答案。

样例输入输出

5 3
1 2 3 2 1
4
C
R 2
P 5 5 2
CS 4 1
4
1

数据范围

对于 60%60\% 的数据,N1000N \le 1000Q1000Q \le 1000

对于 100%100\% 的数据,N500000N \le 500000Q500000Q \le 500000c1000c \le 1000

关于旋转和翻转

注意旋转命令旋转“珠子”但不改变“位置”的编号,而反转命令始终以位置 11 为对称轴。例如当 N=10N=10 时,项链上的位置编号如图 1:

但注意此时项链上的位置编号仍然如图 1 所示,于是翻转的对称轴不变。因而再执行一次 F 命令时,项链的颜色如图 4 所示。

关于 CountSegment 命令

CS 命令表示查询一个“线段”中有多少个“部分”。尤其注意当查询的长度等于 NN 时,我们仍然将查询部分作为“线段”理解。

例如在图 4 所示的情况中,执行 CS 1 10 命令,查询从位置 11 开始到位置 1010 结束的这个长度为 1010 的线段中有多少个“部分”,于是得到返回值 33。与之形成对照的是,若执行 C 命令,返回值则为 22