CF1729E.Guess the Cycle Size

普及/提高-

通过率:0%

AC君温馨提醒

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

题目描述

This is an interactive problem.

I want to play a game with you...

We hid from you a cyclic graph of nn vertices ( 3n10183 \le n \le 10^{18} ). A cyclic graph is an undirected graph of nn vertices that form one cycle. Each vertex belongs to the cycle, i.e. the length of the cycle (the number of edges in it) is exactly nn . The order of the vertices in the cycle is arbitrary.

You can make queries in the following way:

  • "? a b" where 1a,b10181 \le a, b \le 10^{18} and aba \neq b . In response to the query, the interactor outputs on a separate line the length of random of two paths from vertex aa to vertex bb , or -1 if max(a,b)>n\max(a, b) > n . The interactor chooses one of the two paths with equal probability. The length of the path —is the number of edges in it.

You win if you guess the number of vertices in the hidden graph (number nn ) by making no more than 5050 queries.

Note that the interactor is implemented in such a way that for any ordered pair (a,b)(a, b) , it always returns the same value for query "? a b", no matter how many such queries. Note that the "? b a" query may be answered differently by the interactor.

The vertices in the graph are randomly placed, and their positions are fixed in advance.

Hacks are forbidden in this problem. The number of tests the jury has is 5050 .

输入格式

输出格式

You can make no more than 5050 of queries. To make a query, output on a separate line:

  • "? a b", where 1a,b10181 \le a, b \le 10^{18} and aba \neq b . In response to the query, the interactor will output on a separate line the length of a random simple path from vertex aa to vertex bb (not to be confused with the path from bb to aa ), or 1-1 if max(a,b)>n\max(a, b) > n . The interactor chooses one of the two paths with equal probability.

If your program gets a number 0 as a result of a query, it means that the verdict for your solution is already defined as "wrong answer" (for example, you made more than 5050 queries or made an invalid query). In this case, your program should terminate immediately. Otherwise, in this scenario you may get a random verdict "Execution error", "Exceeded time limit" or some other verdict instead of "Wrong answer".

The answer, like queries, print on a separate line. The output of the answer is not counted as a query when counting them. To print it, use the following format:

  • "! n": the expected size of the hidden graph ( 3n10183 \le n \le 10^{18} ).

After that, your program should terminate.

After the output of the next query, be sure to use stream cleaning functions so that some of your output is not left in some buffer. For example, in C++ you should use function flush(stdout), in Java call System.out.flush(), in Pascal flush(output) and stdout.flush() for Python.

Note that the interactor is implemented in such a way that for any ordered pair (a,b)(a, b) , it always returns the same value for query "? a b", no matter how many such queries. Note that the "? b a" query may be answered differently by the interactor.

The vertices in the graph are randomly placed, and their positions are fixed in advance.

Hacks are forbidden in this problem. The number of tests the jury has is 5050 .

输入输出样例

  • 输入#1

    1
    
    2
    
    -1

    输出#1

    ? 1 2
    
    ? 1 3
    
    ? 1 4
    
    ! 3

说明/提示

In the first example, the graph could look like this

The lengths of the simple paths between all pairs of vertices in this case are 11 or 22 .

  • The first query finds out that one of the simple paths from vertex 11 to vertex 22 has a length of 11 .
  • With the second query, we find out that one of the simple paths from vertex 11 to vertex 33 has length 22 .
  • In the third query, we find out that vertex 44 is not in the graph. Consequently, the size of the graph is 33 .
首页