#P12810. [AMPPZ 2019] Henry Porter and the Palindromic Radius
[AMPPZ 2019] Henry Porter and the Palindromic Radius
Description
A young wizard, Henry Porter, has just received sad news – the eldest of his family, uncle Markus Radius Palindromus Black, passed away. Uncle Markus had a reputation of being a quite eccentric person, using complicated binary magic, and was also known to be very, very rich.
Black’s will states that Henry should inherit his mysterious chamber of treasures. To enter and claim it, however, the young wizard must say the right password , which is a word of length , consisting of characters 0 and 1. Uncle Markus did not tell Henry the password – it certainly wouldn’t be his style. Instead, he computed, for every , the palindromic radius – the largest possible integer such that the word of length centered at exists and is a palindrome. Henry then only received the values . For example, if the password was 10111010, Henry would get the sequence .
Henry would prefer Uncle Markus not to test his algorithmic skills while being dead, but, well, there is no one to complain. And he has good friends who can help him! Given the sequence left by Markus in his will, determine all possible passwords that correspond to it. As the will is battered and stained, it might even happen that there is no solution at all.
Input Format
The first line of input contains the number of test cases (). The test cases follow, each one in the following format:
A test case consists of two lines. The first line contains a single integer – the length of both the password and Black’s sequence (). The second line contains integers () – the palindromic radii for all the characters in the password.
The sum of values over all test cases does not exceed .
Output Format
For every test case, output first the number of possible passwords.
If , output in the next lines all the solutions as -sequences.
The sequences must be given in lexicographic order.
You may assume that does not exceed 100.
1
8
0 1 0 3 0 1 1 0
4
00010000
01000101
10111010
11101111
京公网安备 11011102002149号