题目十六
C. BA-String
[原题链接]
[题目翻译]
给定一个整数k和一个字符串s,该字符串由字符’a’(小写拉丁字母)和(’*’)组成。
每个星号应替换为几个(从0到k包括在内)小写拉丁字母"b"。不同的星号可以用不同数量的字母b代替。
替换出来的结果称为BA-string。
两个字符串a和b是不同的,如果它们有不同长度或存在这样一个位置i使得ai≠bi。
字符串a是在字典序上小于字符串b,当且仅当以下条件成立之一时:
a是b的前缀,但是a≠b;
a和b第一个位置不同,字符串a有一个字母在字母表中比b中相应的字母出现的更早
现在考虑所有不同的ba字符串,并找出它们中字典序上第a个最小的。
[输入]
第一行包含一个整数t (1≤t≤2000)—表示测试用例的数量
每个测试用例的第一行包含三个整数n,k和x (1≤n≤2000; 0≤k≤2000; 1≤x≤10e18)。n是字符串s的长度。
每个测试用例的第二行是一个字符串s,它由n个字符组成,每个字符要么是a(小写字母),要么是*(星号)
n除以所有的测试用例的和不超过2000.对于每一个测试用例,a不超过ba字符串的总数
字符串s至少包含一个字符’a’
[输出]
对于每一个测试用例输出一个字符串,只包含字符’b’和’a’(小写拉丁字母)—第a个字典上的最小的ba字符串