[Solution] Ela Sorting Books Codeforces Solution
books must be split into compartments on the bookshelf ( is divisible by ). Each book is represented by a lowercase Latin letter from 'a' to 'y' inclusively, which is the beginning letter in the title of the book.
Ela must stack exactly books in each compartment. After the books are stacked, for each compartment indexed from to , she takes the minimum excluded (MEX) letter of the multiset of letters formed by letters representing all books in that compartment, then combines the resulting letters into a string. The first letter of the resulting string is the MEX letter of the multiset of letters formed by the first compartment, the second letter of the resulting string is the MEX letter of the multiset of letters formed by the second compartment, ... and so on. Please note, under the constraint of this problem, MEX letter can always be determined for any multiset found in this problem because 'z' is not used.
What is the lexicographically greatest resulting string possible that Ela can create?
A string is lexicographically greater than a string if and only if one of the following holds:
- is a prefix of , but ;
- in the first position where and differ, the string has a letter that appears later in the alphabet than the corresponding letter in .
The minimum excluded (MEX) letter of a multiset of letters is the letter that appears earliest in the alphabet and is not contained in the multiset. For example, if a multiset of letters contains letters 'b', 'a', 'b', 'c', 'e', 'c', 'f' respectively, then the MEX letter of this compartment is 'd', because 'd' is not included in the multiset, and all letters comes before 'd' in the alphabet, namely 'a', 'b' and 'c', are included in the multiset.
Each test contains multiple test cases. The first line contains the number of test cases (). Description of the test cases follows.
The first line of each test case contains two integers and (; ). It is guaranteed that is divisible by .
The second line of each test case contains a string of lowercase Latin letters from 'a' to 'y' inclusively. Each letter represents the starting letter of the title of a book in the initial heap.
It is guaranteed that the sum of over all test cases does not exceed .
For each test case, output a string of letters which is the most optimal string that Ela can find.
In the first test case, the books can be divided into compartments as below:
- the first compartment contains the books with indices : 'c', 'a', 'b', 'd' 'e'
- the second compartment contains the books with indices : 'c', 'c', 'a', 'b' 'd'
- the third compartment contains the remaining books : 'a', 'a', 'a', 'c' 'b'
Therefore, the answer is 'edb'. It can be proven that there is no way that Ela can arrange the books so that it results in a lexicographically greater string.
No comments:
Post a Comment