#L3544. 「CSP-S 2021」回文
「CSP-S 2021」回文
题目描述
给定正整数 和整数序列 ,在这 个数中, 分别各出现恰好 次。现在进行 次操作,目标是创建一个长度同样为 的序列 ,初始时 为空序列,每次可以进行以下两种操作之一:
-
将序列 的开头元素加到 的末尾,并从 中移除。
-
将序列 的末尾元素加到 的末尾,并从 中移除。
我们的目的是让 成为一个回文数列,即令其满足对所有 ,有 。请你判断该目的是否能达成,如果可以,请输出字典序最小的操作方案。
输入格式
从文件 palin.in 中读入数据。
每个测试点包含多组测试数据。
输入的第一行,包含一个整数 ,表示测试数据的组数。对于每组测试数据:
第一行,包含一个正整数 。
第二行,包含 个用空格隔开的整数 。
输出格式
输出到文件 palin.out 中。
对每组测试数据输出一行答案。
如果无法生成出回文数列,输出一行 -1,否则输出一行一个长度为 的、由字符 L 或 R 构成的字符串(不含空格),其中 L 表示移除开头元素的操作 1,R 表示操作 2。
你需要输出所有方案对应的字符串中字典序最小的一个。
字典序的比较规则如下:长度均为 的字符串 比 字典序小,当且仅当存在下标 使得对于每个 有 且 。
2
5
4 1 2 4 5 3 1 2 3 5
3
3 2 1 2 1 3
LRRLLRRRRL
-1
在第一组数据中,生成的 数列是 ,可以看出这是一个回文数列。
另一种可能的操作方案是 LLRRLLLRRR,但比答案方案的字典序要大。
数据规模与约定
令 表示所有 组测试数据中 的和。
对所有测试点保证 ,。