CF1689A.Lex String
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
Kuznecov likes art, poetry, and music. And strings consisting of lowercase English letters.
Recently, Kuznecov has found two strings, a and b , of lengths n and m respectively. They consist of lowercase English letters and no character is contained in both strings.
Let another string c be initially empty. Kuznecov can do the following two types of operations:
- Choose any character from the string a , remove it from a , and add it to the end of c .
- Choose any character from the string b , remove it from b , and add it to the end of c .
But, he can not do more than k operations of the same type in a row. He must perform operations until either a or b becomes empty. What is the lexicographically smallest possible value of c after he finishes?
A string x is lexicographically smaller than a string y if and only if one of the following holds:
- x is a prefix of y , but x=y ;
- in the first position where x and y differ, the string x has a letter that appears earlier in the alphabet than the corresponding letter in y .
输入格式
There are several test cases in the input data. The first line contains a single integer t ( 1≤t≤100 ) — the number of test cases. This is followed by the test cases description.
The first line of each test case contains three integers n , m , and k ( 1≤n,m,k≤100 ) — parameters from the statement.
The second line of each test case contains the string a of length n .
The third line of each test case contains the string b of length m .
The strings contain only lowercase English letters. It is guaranteed that no symbol appears in a and b simultaneously.
输出格式
In each test case, output a single string c — the answer to the problem.
输入输出样例
输入#1
3 6 4 2 aaaaaa bbbb 5 9 3 caaca bedededeb 7 7 1 noskill wxhtzdy
输出#1
aabaabaa aaabbcc dihktlwlxnyoz
说明/提示
In the first test case, it is optimal to take two 'a's from the string a and add them to the string c . Then it is forbidden to take more characters from a , hence one character 'b' from the string b has to be taken. Following that logic, we end up with c being 'aabaabaa' when string a is emptied.
In the second test case it is optimal to take as many 'a's from string a as possible, then take as many 'b's as possible from string b . In the end, we take two 'c's from the string a emptying it.