CF1363D.Guess The Maximums

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

This is an interactive problem.

Ayush devised a new scheme to set the password of his lock. The lock has kk slots where each slot can hold integers from 11 to nn . The password PP is a sequence of kk integers each in the range [1,n][1, n] , ii -th element of which goes into the ii -th slot of the lock.

To set the password of his lock, Ayush comes up with an array AA of nn integers each in the range [1,n][1, n] (not necessarily distinct). He then picks kk non-empty mutually disjoint subsets of indices S1,S2,...,SkS_1, S_2, ..., S_k (SiijSj=)(S_i \underset{i \neq j} \cap S_j = \emptyset) and sets his password as Pi=maxjSiA[j]P_i = \max\limits_{j \notin S_i} A[j] . In other words, the ii -th integer in the password is equal to the maximum over all elements of AA whose indices do not belong to SiS_i .

You are given the subsets of indices chosen by Ayush. You need to guess the password. To make a query, you can choose a non-empty subset of indices of the array and ask the maximum of all elements of the array with index in this subset. You can ask no more than 12 queries.

输入格式

The first line of the input contains a single integer tt (1t10)(1 \leq t \leq 10) — the number of test cases. The description of the test cases follows.

The first line of each test case contains two integers nn and kk (2n1000,1kn)(2 \leq n \leq 1000, 1 \leq k \leq n) — the size of the array and the number of subsets. kk lines follow. The ii -th line contains an integer cc (1c<n)(1 \leq c \lt n) — the size of subset SiS_i , followed by cc distinct integers in the range [1,n][1, n] — indices from the subset SiS_i .

It is guaranteed that the intersection of any two subsets is empty.

输出格式

To ask a query print a single line:

  • In the beginning print "? c " (without quotes) where cc (1cn)(1 \leq c \leq n) denotes the size of the subset of indices being queried, followed by cc distinct space-separated integers in the range [1,n][1, n] .

For each query, you will receive an integer xx — the maximum of value in the array among all the indices queried. If the subset of indices queried is invalid or you exceeded the number of queries (for example one of the indices is greater than nn ) then you will get x=1x = -1 . In this case, you should terminate the program immediately.

When you have guessed the password, print a single line "! " (without quotes), followed by kk space-separated integers — the password sequence.

Guessing the password does not count towards the number of queries asked.

After this, you should read a string. If you guess the password correctly, you will receive the string "Correct". In this case, you should continue solving the remaining test cases. If the guessed password is incorrect, you will receive the string "Incorrect". In this case, you should terminate the program immediately.

The interactor is not adaptive. The array AA does not change with queries.

After printing a query do not forget to output end of line and flush the output. Otherwise, you will get Idleness limit exceeded. To do this, use:

  • fflush(stdout) or cout.flush() in C++;
  • System.out.flush() in Java;
  • flush(output) in Pascal;
  • stdout.flush() in Python;
  • see documentation for other languages.

Hacks

To hack the solution use the following test format:

The first line of the input should contain a single integer tt (1t10)(1 \leq t \leq 10) — the number of test cases.

The first line of each test case should contain two integers nn and kk (2n1000,1kn)(2 \leq n \leq 1000, 1 \leq k \leq n) — the size of the array and the number of subsets. The next line should consist of nn space separated integers in the range [1,n][1, n] — the array AA . kk lines should follow. The ii -th line should contain an integer cc (1c<n)(1 \leq c \lt n) — the size of subset SiS_i , followed by cc distinct integers in the range [1,n][1, n] — indices from the subset SiS_i .

The intersection of any two subsets has to be empty.

输入输出样例

  • 输入#1

    1
    4 2
    2 1 3
    2 2 4
    
    1
    
    2
    
    3
    
    4
    
    Correct

    输出#1

    ? 1 1
    
    ? 1 2
    
    ? 1 3
    
    ? 1 4
    
    ! 4 3

说明/提示

The array AA in the example is [1,2,3,4][1, 2, 3, 4] . The length of the password is 22 . The first element of the password is the maximum of A[2]A[2] , A[4]A[4] (since the first subset contains indices 11 and 33 , we take maximum over remaining indices). The second element of the password is the maximum of A[1]A[1] , A[3]A[3] (since the second subset contains indices 22 , 44 ).

Do not forget to read the string "Correct" / "Incorrect" after guessing the password.

首页