有个名为 Looploop 的玩具,这个玩具有 N 个元素,以循环方式排列。有一个箭头指向其中一个元素,还有两个预设参数 k1 和 k 2。
上图显示了一个由 6 个元素组成的循环。假设预设参数 k1=3,k2 =4,对这个玩具做 6 种操作,请对这些操作中的每个查询都给出答案。
从箭头指向的元素开始,将顺时针方向第 1~k2 个元素加 x 。
从箭头指向的元素开始,将顺时针方向第 1~k1 个元素反转。
在箭头指向的元素右侧(顺时针方向)插入一个新元素 x 。
删除箭头指向的元素,然后将箭头移到其右侧的元素上。
x 只可以是 1 或 2。若 x=1,则向左(逆时针方向)移动箭头;若 x=2,则向右移动箭头。
在一行中输出箭头指向的元素。
输入包含多个测试用例。每个测试用例的第 1 行都包括 N、M 、k1 、k2 (2≤k 1 对每个测试用例,都在第 1 行输出用例数(格式如输出样例),然后对用例中的每个查询,都单行输出箭头指向的元素。 5 1 2 4 3 4 5 6 7 query 5 13 2 4 1 2 3 4 5 move 2 query insert 8 reverse query add 2 query move 1 query move 1 query delete query 0 0 0 0 Case #1: 3 Case #2: 2 8 10 1 5 1 本问题包含6种操作:区间修改、区间反转、插入、删除、移动、查询。 从箭头指向的元素开始,将顺时针方向第 1~k2 个元素加 x。 从箭头指向的元素开始,将顺时针方向第 1~k1个元素反转。 在箭头指向的元素右侧插入一个新元素 x 。 删除箭头指向的元素,然后将箭头移到右侧的元素上。 若 x 等于1,则箭头向左移一位;若x 等于2,则箭头向右移一位。 输出箭头指向的元素。 测试用例 2 的输入数据 5 13 2 4,表示元素的初始数量 N=5,将执行的操作总数 M=13,两个预设参数 k1=2,k2=4。 向右移动。query:查询箭头所指向的元素,输出 2。 在箭头指向的元素右侧(顺时针方向)插入 8。 从箭头指向的元素开始,将顺时针方向第 1~k1(k 1 =2)个元素反转。query:查询箭头指向的元素,输出 8。 从箭头指向的元素开始,将顺时针方向第 1~k2 (k2 =4)个元素加 2。query:查询箭头指向的元素,输出 10。 将箭头向左移动1位。query:查询箭头指向的元素,输出 1。 将箭头向左移动 1 位。query:查询箭头指向的元素,输出 5。 删除箭头指向的元素,然后将箭头移至右侧元素上。query:查询箭头指向的元素,输出1 本题可采用伸展树解决,在首尾添加两个虚节点。箭头指向的元素永远在第 2 个位置(首尾添加了虚节点),过程如下。 从箭头指向的元素开始,将顺时针方向第 1~k2 个元素加 x 。箭头所指向的元素在第 2 个位置,因此执行区间修改 Add(2,k2+1, x )。 从箭头指向的元素开始,将顺时针方向第 1~k1个元素反转。执行区间反转 Reverse(2, k1 +1)。 在箭头指向的元素右侧插入x 。在第 2 个位置右侧插入x ,执行 Insert(2, x )。 删除箭头指向的元素,将箭头移到右侧的元素上。删除第 2 个位置的元素,执行Delete(2)。 若 x=1,则箭头向左移一位,相当于删除元素 An ,把 An 放在第1个位置之后。执行 y=Delete(sum+1); Insert(1, y),sum 为实际的元素个数。 若 x =2,则箭头向右移一位,相当于把元素 A1 删除,然后把 A1 放在 An 之后。执行y=Delete(2); Insert(sum+1, y )。 2 输出
三 输入和输出样例
1 输入样例
2 输出样例
四 分析
1 add x
2 reverse
3 insert x
4 delete
5 move x
6 query
五 图解
1 初始状态为1 2 3 4 5。
2 move 2
3 insert 8
4 reverse
5 add 2
6 move 1
7 move 1
8 delete
六 算法设计
1 add x
2 reverse
3 insert x
4 delete
5 move x
七 代码
八 测试