#P6913. [ICPC 2015 WF] Tile Cutting

[ICPC 2015 WF] Tile Cutting

题目描述

Youssef is a Moroccan tile installer who specializes in mosaics like the one shown on the right. He has rectangular tiles of many dimensions at his disposal, and the dimensions of all his tiles are integer numbers of centimeters. When Youssef needs parallelogram-shaped tiles, he cuts them from his supply on hand. To make this work easier, he invented a tile cutting machine that superimposes a centimeter grid on the cutting surface to guide the cuts on the tiles. Due to machine limitations, aesthetic sensibilities, and Youssef’s dislike of wasted tiles, the following rules determine the possible cuts.

The rectangular tile to be cut must be positioned in the bottom left corner of the cutting surface and the edges must be aligned with the grid lines.

The cutting blade can cut along any line connecting two different grid points on the tile boundary as long as the points are on adjacent boundary edges.

The four corners of the resulting parallelogram tile must lie on the four sides of the original rectangular tile.

No edge of the parallelogram tile can lie along an edge of the rectangular tile.

Figure 1 shows the eight different ways in which a parallelogram tile of area 44 square centimeters can be cut out of a rectangular tile, subject to these restrictions.

Figure 1: The eight different ways for cutting a parallelogram of area 4.

Youssef needs to cut tiles of every area between aloa_{\text {lo}} and ahia_{\text {hi}}. Now he wonders, for which area aa in this range can he cut the maximum number of different tiles?

输入格式

The input consists of multiple test cases. The first line of input contains an integer nn (1n5001 \le n \le 500), the number of test cases. The next nn lines each contain two integers alo,ahia_{\text {lo}}, a_{\text {hi}} ($1 \le a_{\text {lo}} \le a_{\text {hi}} \le 500\, 000$), the range of areas of the tiles.

输出格式

For each test case aloa_{\text {lo}}, ahia_{\text {hi}}, display the value aa between aloa_{\text {lo}} and ahia_{\text {hi}} such that the number of possible ways to cut a parallelogram of area aa is maximized as well as the number of different ways ww in which such a parallelogram can be cut. If there are multiple possible values of aa display the smallest one.

2
4 4
2 6

4 8
6 20

提示

Time limit: 11000 ms, Memory limit: 1048576 kB.

International Collegiate Programming Contest (ACM-ICPC) World Finals 2015