Hide

Problem H
Exploring Delsjön

Olle likes to take walks in the woods around Delsjön. In the woods, there are N glades, and N1 trails that connect them. It is possible to travel between every pair of glades using one or more trails. It takes exactly one minute to travel along one trail to another glade. The forest can only be entered and exited via glades that have exactly one trail connecting the glade to the rest of the forest. There are K such glades, and we will call them exit glades. Olle has taken enough walks to know the time it takes to walk between every pair of the K exit glades.

He wonders if this information is enough to map out the forest. Your task is to find a possible layout of the forest that is consistent with Olle’s information, using at most 2000 glades. More exactly, you should first decide on the number of glades G, and then decide the G1 trails connecting the glades. The layout should be such that glade 1 is the first exit glade, glade 2 is the second exit glade in the same order as the input, up to K. It must also be possible to walk between every pair of glades in your layout.

Input

The first line of input contains the integer K (2K1000), the number of exit glades.

Then follow K lines, the i:th describing the distances between exit glade i and the other exit glades. Each line i will contain K integers, di,1,di,2,,di,K (1di,j1000), each di,j meaning that it takes di,j minutes to get from glade i to j. Note that these distances are symmetric: di,j=dj,i for all i,j.

It is guaranteed that the input is created such that there always exists a layout where G1000.

Output

First, print an integer G (KG2000), the number of trails in your layout.

Then, print G1 lines, each containing two integers a,b (1a,bG), meaning that there is a trail between glade a and b. Glade 1 should be the first exit glade, glade 2 the second exit glade and so on.

If your layout of Delsjön is consistent with the information given above and it is possible to travel between every pair of glades using one or more trails, it will be accepted.

Scoring

Your solution will be tested on a set of test groups, each worth a number of points. Each test group contains a set of test cases. To get the points for a test group you need to solve all test cases in the test group.

Group

Points

Constraints

1

50

There is a solution with G100.

2

50

No additional constraints.

Explanation of Sample 1

One possible way that Delsjön could look like is shown below:

\includegraphics[width=0.2\textwidth ]{sample-1.png}

The black glades are exit glades. You can verify that the distances between each pair of exit glades matches those in the input.

Explanation of Sample 2

Given the distances of sample 2, Delsjön could look like what is shown below:

\includegraphics[width=0.4\textwidth ]{sample-2.png}
Sample Input 1 Sample Output 1
3
0 2 3
2 0 3
3 3 0
5
2 4
4 1
3 5
5 4
Sample Input 2 Sample Output 2
4
0 5 5 5
5 0 2 4
5 2 0 4
5 4 4 0
9
2 5
5 6
6 7
7 8
8 1
3 5
4 9
9 6
Hide

Please log in to submit a solution to this problem

Log in