[Solution] Phase Shift Codeforces Solution
There was a string which was supposed to be encrypted. For this reason, all lowercase English letters were arranged in a circle in some order, afterwards, each letter in was replaced with the one that follows in clockwise order, in that way the string was obtained.
You are given a string . Determine the lexicographically smallest string that could be a prototype of the given string .
A string is lexicographically smaller than a string of the same length if and only if:
- in the first position where and differ, the string has a letter, that appears earlier in the alphabet than the corresponding letter in .
The first line of the input contains a single integer () — the number of test cases. The description of test cases follows.
The first line of each test case contains one integer () — the length of the string .
The next line contains the string of the length , containing lowercase English letters.
It is guaranteed that the sum of over all test cases doesn't exceed .
For each test case, output a single line containing the lexicographically smallest string which could be a prototype of .
In the first test case, we couldn't have the string "a", since the letter a would transit to itself. Lexicographically the second string "b" is suitable as an answer.
In the second test case, the string "aa" is not suitable, since a would transit to itself. "ab" is not suitable, since the circle would be closed with letters, but it must contain all . The next string "ac" is suitable.
Below you can see the schemes for the first three test cases. The non-involved letters are skipped, they can be arbitrary placed in the gaps.
No comments:
Post a Comment