#include <stdio.h>
#include <stdlib.h>

void solve(int N)
{
	int i, ans[2][1001];
	printf("?");
	for (i = 1; i < N; i++) printf(" %d", i % 2);
	printf("\n");
	fflush(stdout);
	for (i = 1; i <= N; i++) scanf("%d", &(ans[0][i]));
	printf("?");
	for (i = 1; i < N; i++) printf(" %d", (i + 1) % 2);
	printf("\n");
	fflush(stdout);
	for (i = 1; i <= N; i++) scanf("%d", &(ans[1][i]));
	printf("! %d", ans[0][1]);
	for (i = 2; i <= N; i++) {
		if (ans[0][i-1] != ans[0][i]) printf(" %d", ans[0][i]);
		else if (ans[1][i-1] != ans[1][i]) printf(" %d", ans[1][i]);
		else exit(-1);
	}
	printf("\n");
	fflush(stdout);
}

int main()
{
	int t, T, N;
	scanf("%d", &T);
	for (t = 1; t <= T; t++) {
		scanf("%d", &N);
		solve(N);
	}
	return 0;
}