#include #include 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; }