CF1455F.String and Operations

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

You are given a string ss consisting of nn characters. These characters are among the first kk lowercase letters of the Latin alphabet. You have to perform nn operations with the string.

During the ii -th operation, you take the character that initially occupied the ii -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 kk -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 kk -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, k=20k = 20 , and the sequence of operations is URLD. Then the string is transformed as follows:

  1. the first operation is U, so we change the underlined letter in test to the next one in the first 2020 Latin letters, which is a. The string is now aest;
  2. the second operation is R, so we swap the underlined letter with the next one in the string aest. The string is now aset;
  3. 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 22 -nd character of the string, but it was initially the 33 -rd one, so the 33 -rd operation is performed to it). The resulting string is saet;
  4. the fourth operation is D, so we change the underlined letter in saet to the previous one in the first 2020 Latin letters, which is s. The string is now saes.

The result of performing the sequence of operations is saes.

Given the string ss and the value of kk , find the lexicographically smallest string that can be obtained after applying a sequence of operations to ss .

输入格式

The first line contains one integer tt ( 1t10001 \le t \le 1000 ) — the number of test cases.

Each test case consists of two lines. The first line contains two integers nn and kk ( 1n5001 \le n \le 500 ; 2k262 \le k \le 26 ).

The second line contains a string ss consisting of nn characters. Each character is one of the kk 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 ss using one sequence of operations.

输入输出样例

  • 输入#1

    6
    4 2
    bbab
    7 5
    cceddda
    6 5
    ecdaed
    7 4
    dcdbdaa
    8 3
    ccabbaca
    5 7
    eabba

    输出#1

    aaaa
    baccacd
    aabdac
    aabacad
    aaaaaaaa
    abadb
首页