308690: CF1558C. Bottom-Tier Reversals
Memory Limit:512 MB
Time Limit:2 S
Judge Style:Text Compare
Creator:
Submit:0
Solved:0
Description
Bottom-Tier Reversals
题意翻译
给定一个长度为奇数的排列 $a_1, a_2, \dots, a_n$,你需要构造一组长度不超过的 $\frac 52 n$ 的操作序列 $s_1, s_2, \dots, s_k$,使得: * $1 \le s_i \le n$,$s_i$ 为奇数; * 按从前往后的顺序,对于每个 $s_i$,反转排列的前 $s_i$ 项,最后得到的排列中 $a_i = i$。题目描述
You have a permutation: an array $ a = [a_1, a_2, \ldots, a_n] $ of distinct integers from $ 1 $ to $ n $ . The length of the permutation $ n $ is odd. You need to sort the permutation in increasing order. In one step, you can choose any prefix of the permutation with an odd length and reverse it. Formally, if $ a = [a_1, a_2, \ldots, a_n] $ , you can choose any odd integer $ p $ between $ 1 $ and $ n $ , inclusive, and set $ a $ to $ [a_p, a_{p-1}, \ldots, a_1, a_{p+1}, a_{p+2}, \ldots, a_n] $ . Find a way to sort $ a $ using no more than $ \frac{5n}{2} $ reversals of the above kind, or determine that such a way doesn't exist. The number of reversals doesn't have to be minimized.输入输出格式
输入格式
Each test contains multiple test cases. The first line contains the number of test cases $ t $ ( $ 1 \le t \le 100 $ ). Description of the test cases follows. The first line of each test case contains a single integer $ n $ ( $ 3 \le n \le 2021 $ ; $ n $ is odd) — the length of the permutation. The second line contains $ n $ distinct integers $ a_1, a_2, \ldots, a_n $ ( $ 1 \le a_i \le n $ ) — the permutation itself. It is guaranteed that the sum of $ n $ over all test cases does not exceed $ 2021 $ .
输出格式
For each test case, if it's impossible to sort the given permutation in at most $ \frac{5n}{2} $ reversals, print a single integer $ -1 $ . Otherwise, print an integer $ m $ ( $ 0 \le m \le \frac{5n}{2} $ ), denoting the number of reversals in your sequence of steps, followed by $ m $ integers $ p_i $ ( $ 1 \le p_i \le n $ ; $ p_i $ is odd), denoting the lengths of the prefixes of $ a $ to be reversed, in chronological order. Note that $ m $ doesn't have to be minimized. If there are multiple answers, print any.
输入输出样例
输入样例 #1
3
3
1 2 3
5
3 4 5 2 1
3
2 1 3
输出样例 #1
4
3 3 3 3
2
3 5
-1