CF1819B.The Butcher
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
Anton plays his favorite game "Defense of The Ancients 2" for his favorite hero — The Butcher. Now he wants to make his own dinner. To do this he will take a rectangle of height h and width w , then make a vertical or horizontal cut so that both resulting parts have integer sides. After that, he will put one of the parts in the box and cut the other again, and so on.
More formally, a rectangle of size h×w can be cut into two parts of sizes x×w and (h−x)×w , where x is an integer from 1 to (h−1) , or into two parts of sizes h×y and h×(w−y) , where y is an integer from 1 to (w−1) .
He will repeat this operation n−1 times, and then put the remaining rectangle into the box too. Thus, the box will contain n rectangles, of which n−1 rectangles were put in the box as a result of the cuts, and the n -th rectangle is the one that the Butcher has left after all n−1 cuts.
Unfortunately, Butcher forgot the numbers h and w , but he still has n rectangles mixed in random order. Note that Butcher didn't rotate the rectangles, but only shuffled them. Now he wants to know all possible pairs (h,w) from which this set of rectangles can be obtained. And you have to help him do it!
It is guaranteed that there exists at least one pair (h,w) from which this set of rectangles can be obtained.
输入格式
Each test consists of multiple test cases. The first line contains a single integer t ( 1≤t≤104 ) — the number of test cases. The description of test cases follows.
The first line of each test case contains a single integer n ( 1≤n≤2⋅105 ) — the number of rectangles obtained.
The i -th of the next n lines contains two integers ai and bi ( 1≤ai,bi≤106 ) — the height and width of the i -th rectangle.
It is guaranteed that the sum of n over all test cases does not exceed 2⋅105 .
输出格式
For each test case, on the first line output a single integer m — the number of pairs (h,w) denoting the sizes of rectangles from which the given rectangles can be obtained. Two rectangles are considered different if they have different heights or widths.
On each of the following m lines print output integers hi and wi — the height and width of the rectangle from which the given rectangles can be obtained. You can output the rectangles in any order.
输入输出样例
输入#1
4 3 1 2 3 5 1 3 3 1 1 1 1 1 1 1 10 10 4 3 2 5 5 2 2 8 7
输出#1
1 4 5 2 1 3 3 1 1 10 10 1 13 7
说明/提示
In the first test case, Butcher could only have a rectangle of size 4×5 . Then the cuts could look like this (first the green cut was made, then the red one):
In the second test case, Butcher could have either a rectangle of 1×3 or 3×1 . The cuts would have looked like this (first the green cut was made, then the red cut):
In the third test case, Butcher did not make any cuts, so the rectangle is 10×10 .