Serval and Snake

题意翻译

#### 题意翻译 在 $n\times n$ 的方格上有一条链(不一定是直的),你需要通过查询来找出这条链的两个端点。 你的查询形如 `x1 y1 x2 y2` ,这可以确定一个矩形,查询结果是链在矩形上的边数。 你最多能进行 $2019$ 次查询。最后请输出 `x1 y1 x2 y2` ,表示链两个端点的坐标。 #### 数据范围 $n \le 1000$

题目描述

This is an interactive problem. Now Serval is a senior high school student in Japari Middle School. However, on the way to the school, he must go across a pond, in which there is a dangerous snake. The pond can be represented as a $ n \times n $ grid. The snake has a head and a tail in different cells, and its body is a series of adjacent cells connecting the head and the tail without self-intersecting. If Serval hits its head or tail, the snake will bite him and he will die. Luckily, he has a special device which can answer the following question: you can pick a rectangle, it will tell you the number of times one needs to cross the border of the rectangle walking cell by cell along the snake from the head to the tail. The pictures below show a possible snake and a possible query to it, which will get an answer of $ 4 $ . ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1153E/53fbbb51794507f6b8da5b86b0ce29d37f526437.png) ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1153E/310ecca9dbe4567ceada9b3d4a9ef179d283444f.png)Today Serval got up too late and only have time to make $ 2019 $ queries. As his best friend, can you help him find the positions of the head and the tail? Note that two cells are adjacent if and only if they have a common edge in the grid, and a snake can have a body of length $ 0 $ , that means it only has adjacent head and tail. Also note that the snake is sleeping, so it won't move while Serval using his device. And what's obvious is that the snake position does not depend on your queries.

输入输出格式

输入格式


The first line contains a single integer $ n $ ( $ 2\leq n \leq 1000 $ ) — the size of the grid.

输出格式


When you are ready to answer, you should print ! x1 y1 x2 y2, where $ (x_1, y_1) $ represents the position of the head and $ (x_2,y_2) $ represents the position of the tail. You can print head and tail in any order. Interaction To make a query, you should print ? x1 y1 x2 y2 ( $ 1 \leq x_1 \leq x_2 \leq n $ , $ 1\leq y_1 \leq y_2 \leq n $ ), representing a rectangle consisting of all cells $ (x,y) $ such that $ x_1 \leq x \leq x_2 $ and $ y_1 \leq y \leq y_2 $ . You will get a single integer as the answer. After printing a query, do not forget to output the 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. Answer $ -1 $ instead of a valid answer means that you made an invalid query or exceeded the maximum number of queries. Exit immediately after receiving $ -1 $ and you will see Wrong answer verdict. Otherwise you can get an arbitrary verdict because your solution will continue to read from a closed stream. If your program cannot find out the head and tail of the snake correctly, you will also get a Wrong Answer verdict. Hacks To make a hack, print a single integer $ n $ ( $ 2 \leq n \leq 1000 $ ) in the first line, indicating the size of the grid. Then print an integer $ k $ ( $ 2 \leq k \leq n^2 $ ) in the second line, indicating the length of the snake. In the next $ k $ lines, print $ k $ pairs of integers $ x_i, y_i $ ( $ 1 \leq x_i, y_i \leq n $ ), each pair in a single line, indicating the $ i $ -th cell of snake, such that the adjacent pairs are adjacent, and all $ k $ pairs are distinct.

输入输出样例

输入样例 #1

2

1

0

0

输出样例 #1


? 1 1 1 1

? 1 2 1 2

? 2 2 2 2

! 1 1 2 1

输入样例 #2

3

2

0

输出样例 #2


? 2 2 2 2

? 2 1 2 3

! 2 1 2 3

说明

![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1153E/99e348aaccc97b295d205879f6d57ecbaca07b05.png) ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1153E/ce15833a1657c0eb9be15429504c2d44fae6f2bb.png) ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1153E/6d1e7d0b5adac9acef6d724724f8372e63587c4e.png) ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1153E/7ed306531d047140f56616a504d648434c6c8f4f.png)The pictures above show our queries and the answers in the first example. We first made a query for $ (1,1) $ and got an answer $ 1 $ , then found that it must be connected to exactly one other cell. Then we made a query for $ (1,2) $ and got an answer of $ 0 $ , then knew that the snake never entered it. So the cell connected to $ (1,1) $ must be $ (2,1) $ . Then we made a query for $ (2,2) $ and got an answer $ 0 $ , then knew that it never entered $ (2,2) $ as well. So the snake cannot leave $ (2,1) $ , which implies that the answer is $ (1,1) $ and $ (2,1) $ . ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1153E/d087b7ee2ce64273a766b278b890efa6686245bd.png) ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1153E/dc08e571bf34cdde551ce5154f9dbe2876bddd43.png) ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1153E/50d2eabe2572f343f866cfbec6f391d3bf47c83f.png)The pictures above show our queries and the answers in the second example. By making query to $ (2,2) $ and receiving $ 2 $ , we found that the snake occupies $ (2,2) $ . And by making query to rectangle from $ (2,1) $ to $ (2,3) $ and receiving answer $ 0 $ , we knew that it never goes out of the rectangle from $ (2,1) $ to $ (2,3) $ . Since the first answer is $ 2 $ , both $ (2,1) $ and $ (2,3) $ must be occupied but none of others, so the answer is $ (2,1) $ and $ (2,3) $ .