#include <iostream>
using namespace std;
int main() {
int n;
cin >> n; // 读取测试用例的数量
while (n--) {
int an, bn;
cin >> an >> bn; // 读取两个数组的大小
int* a = new int[an]; // 动态分配数组a
int* b = new int[bn]; // 动态分配数组b
int* c = new int[an + bn]; // 动态分配合并后的数组c
// 读取数组a的元素
for (int i = 0; i < an; ++i) {
cin >> a[i];
}
// 读取数组b的元素
for (int i = 0; i < bn; ++i) {
cin >> b[i];
}
int i = 0, j = 0, k = 0;
// 合并两个数组
while (i < an && j < bn) {
if (a[i] < b[j]) {
c[k++] = a[i++];
} else {
c[k++] = b[j++];
}
}
// 如果数组a还有剩余元素
while (i < an) {
c[k++] = a[i++];
}
// 如果数组b还有剩余元素
while (j < bn) {
c[k++] = b[j++];
}
// 输出合并后的数组
for (int i = 0; i < an + bn; ++i) {
if (i > 0) cout << " ";
cout << c[i];
}
cout << endl;
// 释放动态分配的数组内存
delete[] a;
delete[] b;
delete[] c;
}
return 0;
}