#P1455F. String and Operations
String and Operations
Description
You are given a string consisting of characters. These characters are among the first lowercase letters of the Latin alphabet. You have to perform operations with the string.
During the -th operation, you take the character that initially occupied the -th position, and perform one of the following actions with it:
- swap it with the previous character in the string (if it exists). This operation is represented as L;
- swap it with the next character in the string (if it exists). This operation is represented as R;
- cyclically change it to the previous character in the alphabet (b becomes a, c becomes b, and so on; a becomes the -th letter of the Latin alphabet). This operation is represented as D;
- cyclically change it to the next character in the alphabet (a becomes b, b becomes c, and so on; the -th letter of the Latin alphabet becomes a). This operation is represented as U;
- do nothing. This operation is represented as 0.
For example, suppose the initial string is test, , and the sequence of operations is URLD. Then the string is transformed as follows:
- the first operation is U, so we change the underlined letter in test to the next one in the first Latin letters, which is a. The string is now aest;
- the second operation is R, so we swap the underlined letter with the next one in the string aest. The string is now aset;
- the third operation is L, so we swap the underlined letter with the previous one in the string aset (note that this is now the -nd character of the string, but it was initially the -rd one, so the -rd operation is performed to it). The resulting string is saet;
- the fourth operation is D, so we change the underlined letter in saet to the previous one in the first Latin letters, which is s. The string is now saes.
The result of performing the sequence of operations is saes.
Given the string and the value of , find the lexicographically smallest string that can be obtained after applying a sequence of operations to .
The first line contains one integer () — the number of test cases.
Each test case consists of two lines. The first line contains two integers and (; ).
The second line contains a string consisting of characters. Each character is one of the first letters of the Latin alphabet (in lower case).
For each test case, print one line containing the lexicographically smallest string that can be obtained from using one sequence of operations.
Input
The first line contains one integer () — the number of test cases.
Each test case consists of two lines. The first line contains two integers and (; ).
The second line contains a string consisting of characters. Each character is one of the first letters of the Latin alphabet (in lower case).
Output
For each test case, print one line containing the lexicographically smallest string that can be obtained from using one sequence of operations.