Yandex.Algorithm 2011: Round 1 |
---|

Finished |

Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

binary search

dsu

geometry

graphs

sortings

*2600

No tag edit access

The problem statement has recently been changed. View the changes.

×
E. Guard Towers

time limit per test

1.5 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputIn a far away kingdom lives a very greedy king. To defend his land, he built *n* guard towers. Apart from the towers the kingdom has two armies, each headed by a tyrannical and narcissistic general. The generals can't stand each other, specifically, they will never let soldiers of two armies be present in one tower.

During defence operations to manage a guard tower a general has to send part of his army to that tower. Each general asks some fee from the king for managing towers. As they live in a really far away kingdom, each general evaluates his fee in the following weird manner: he finds two remotest (the most distant) towers, where the soldiers of his army are situated and asks for the fee equal to the distance. Each tower is represented by a point on the plane with coordinates (*x*, *y*), and the distance between two points with coordinates (*x*_{1}, *y*_{1}) and (*x*_{2}, *y*_{2}) is determined in this kingdom as |*x*_{1} - *x*_{2}| + |*y*_{1} - *y*_{2}|.

The greedy king was not exactly satisfied with such a requirement from the generals, that's why he only agreed to pay one fee for two generals, equal to the maximum of two demanded fees. However, the king is still green with greed, and among all the ways to arrange towers between armies, he wants to find the cheapest one. Each tower should be occupied by soldiers of exactly one army.

He hired you for that. You should find the minimum amount of money that will be enough to pay the fees. And as the king is also very scrupulous, you should also count the number of arrangements that will cost the same amount of money. As their number can be quite large, it is enough for the king to know it as a remainder from dividing by 10^{9} + 7.

Two arrangements are distinct if the sets of towers occupied by soldiers of the first general are distinct.

Input

The first line contains an integer *n* (2 ≤ *n* ≤ 5000), *n* is the number of guard towers. Then follow *n* lines, each of which contains two integers *x*, *y* — the coordinates of the *i*-th tower (0 ≤ *x*, *y* ≤ 5000). No two towers are present at one point.

Pretest 6 is one of the maximal tests for this problem.

Output

Print on the first line the smallest possible amount of money that will be enough to pay fees to the generals.

Print on the second line the number of arrangements that can be carried out using the smallest possible fee. This number should be calculated modulo 1000000007 (10^{9} + 7).

Examples

Input

2

0 0

1 1

Output

0

2

Input

4

0 0

0 1

1 0

1 1

Output

1

4

Input

3

0 0

1000 1000

5000 5000

Output

2000

2

Note

In the first example there are only two towers, the distance between which is equal to 2. If we give both towers to one general, then we well have to pay 2 units of money. If each general receives a tower to manage, to fee will be equal to 0. That is the smallest possible fee. As you can easily see, we can obtain it in two ways.

Codeforces (c) Copyright 2010-2024 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Mar/01/2024 09:39:19 (h2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|