309281: CF1656G. Cycle Palindrome

Memory Limit:256 MB Time Limit:1 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Cycle Palindrome

题意翻译

### 【前置定义】 1. 回文数列:如果一个长度为 $n$ 的数列 $a_{1\cdots n}$ 满足 $\forall i \in [1,n], a_{i}=a_{n-i+1}$,则称 $a_{1 \cdots n}$ 是回文的。 2. 循环数列:如果一个长度为 $n$ 的数列 $b_{1 \cdots n}$ 满足 $\{ 1,b(1),b^{2}(1),b^3(1) \cdots b^{n-1}(1)\}$ 两两不同,则称 $b_{1 \cdots n}$ 是循环数列。其中 $b^{m}(1)=\underbrace{b(b(\cdots b}_{m \ \text{times}}(1)\cdots))$,如 $b^{2}(1)=b(b(1))$。 3. 排列:对于一个长度为 $n$ 的数列 $c_{1 \dots n}$,如果 $1,2,3,\cdots,n$ 中的每一个数字**都**在 $c_{1 \cdots n}$ **恰好**只出现 $1$ 次,则称 $c_{1 \cdots n}$ 是一个长度为 $n$ 的排列。 ### 【题目描述】 给定一个长度为 $n$ 的数列 $a_{1 \cdots n}$,你需要找到一个**循环数列** $b_{1 \cdots n}$ 使得数列 $\{ a_{b_{1}},a_{b_{2}},a_{b_{3}}, \cdots,a_{b_{n}} \}$ 是一个**回文数列**且 $b$ 是一个长度为 $n$ 的**排列**。 ### 【输入格式】 **多组数据**。 第一行输入一个整数 $T$,表示测试点数目。 对于每个测试点: - 第一行一个整数 $n$,表示数列长度。 - 第二行 $n$ 个整数,表示 $a_{1 \cdots n}$。 ### 【输出格式】 对于每个测试点,如果存在这样的循环数列 $b_{1\cdots n}$,则输出两行:第一行输出一个 `YES`,第二行输出 $b_{1 \cdots n}$。如果有多个 $b_{1 \cdots n}$,输出任意一个即可。 如果不存在这样的 $b_{1 \cdots n}$,则只输出一行,输出 `NO`。 ### 【数据范围】 - $1 \leq T \leq 3 \times 10^{4}$。 - $1 \leq n \leq 2 \times 10^{5},1 \leq \sum n \leq 2 \times 10^{5}$。 - $\forall i \in [1,n], \quad 1 \leq a_{i} \leq n$。 Translated by @HPXXZYY

题目描述

We say that a sequence of $ n $ integers $ a_1, a_2, \ldots, a_n $ is a palindrome if for all $ 1 \leq i \leq n $ , $ a_i = a_{n-i+1} $ . You are given a sequence of $ n $ integers $ a_1, a_2, \ldots, a_n $ and you have to find, if it exists, a cycle permutation $ \sigma $ so that the sequence $ a_{\sigma(1)}, a_{\sigma(2)}, \ldots, a_{\sigma(n)} $ is a palindrome. A permutation of $ 1, 2, \ldots, n $ is a bijective function from $ \{1, 2, \ldots, n\} $ to $ \{1, 2, \ldots, n\} $ . We say that a permutation $ \sigma $ is a cycle permutation if $ 1, \sigma(1), \sigma^2(1), \ldots, \sigma^{n-1}(1) $ are pairwise different numbers. Here $ \sigma^m(1) $ denotes $ \underbrace{\sigma(\sigma(\ldots \sigma}_{m \text{ times}}(1) \ldots)) $ .

输入输出格式

输入格式


The input consists of multiple test cases. The first line contains a single integer $ t $ ( $ 1 \leq t \leq 3 \cdot 10^4 $ ) — the number of test cases. Description of the test cases follows. The first line of each test case contains an integer $ n $ ( $ 2 \leq n \leq 2 \cdot 10^5 $ ) — the size of the sequence. The second line of each test case contains $ n $ integers $ a_1, \ldots, a_n $ ( $ 1 \leq a_i \leq n $ ). The sum of $ n $ for all test cases is at most $ 2 \cdot 10^5 $ .

输出格式


For each test case, output one line with YES if a cycle permutation exists, otherwise output one line with NO. If the answer is YES, output one additional line with $ n $ integers $ \sigma(1), \sigma(2), \ldots, \sigma(n) $ , the permutation. If there is more than one permutation, you may print any.

输入输出样例

输入样例 #1

3
4
1 2 2 1
3
1 2 1
7
1 3 3 3 1 2 2

输出样例 #1

YES
3 1 4 2 
NO
YES
5 3 7 2 6 4 1

Input

题意翻译

### 【前置定义】 1. 回文数列:如果一个长度为 $n$ 的数列 $a_{1\cdots n}$ 满足 $\forall i \in [1,n], a_{i}=a_{n-i+1}$,则称 $a_{1 \cdots n}$ 是回文的。 2. 循环数列:如果一个长度为 $n$ 的数列 $b_{1 \cdots n}$ 满足 $\{ 1,b(1),b^{2}(1),b^3(1) \cdots b^{n-1}(1)\}$ 两两不同,则称 $b_{1 \cdots n}$ 是循环数列。其中 $b^{m}(1)=\underbrace{b(b(\cdots b}_{m \ \text{times}}(1)\cdots))$,如 $b^{2}(1)=b(b(1))$。 3. 排列:对于一个长度为 $n$ 的数列 $c_{1 \dots n}$,如果 $1,2,3,\cdots,n$ 中的每一个数字**都**在 $c_{1 \cdots n}$ **恰好**只出现 $1$ 次,则称 $c_{1 \cdots n}$ 是一个长度为 $n$ 的排列。 ### 【题目描述】 给定一个长度为 $n$ 的数列 $a_{1 \cdots n}$,你需要找到一个**循环数列** $b_{1 \cdots n}$ 使得数列 $\{ a_{b_{1}},a_{b_{2}},a_{b_{3}}, \cdots,a_{b_{n}} \}$ 是一个**回文数列**且 $b$ 是一个长度为 $n$ 的**排列**。 ### 【输入格式】 **多组数据**。 第一行输入一个整数 $T$,表示测试点数目。 对于每个测试点: - 第一行一个整数 $n$,表示数列长度。 - 第二行 $n$ 个整数,表示 $a_{1 \cdots n}$。 ### 【输出格式】 对于每个测试点,如果存在这样的循环数列 $b_{1\cdots n}$,则输出两行:第一行输出一个 `YES`,第二行输出 $b_{1 \cdots n}$。如果有多个 $b_{1 \cdots n}$,输出任意一个即可。 如果不存在这样的 $b_{1 \cdots n}$,则只输出一行,输出 `NO`。 ### 【数据范围】 - $1 \leq T \leq 3 \times 10^{4}$。 - $1 \leq n \leq 2 \times 10^{5},1 \leq \sum n \leq 2 \times 10^{5}$。 - $\forall i \in [1,n], \quad 1 \leq a_{i} \leq n$。 Translated by @HPXXZYY

加入题单

上一题 下一题 算法标签: