Package for this problem was not updated by the problem writer or Codeforces administration after we’ve upgraded the judging servers. To adjust the time limit constraint, solution execution time will be multiplied by 2. For example, if your solution works for 400 ms on judging servers, then value 800 ms will be displayed and used to determine the verdict.

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.

No tag edit access

D. Stars

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputFurik loves painting stars. A star is a shape that results if we take a regular pentagon and paint all diagonals in it.

Recently he decided to teach Rubik to paint stars. After many years of training Rubik could paint stars easily. But now Furik decided to test Rubik and complicated the task. Rubik must paint *n* stars, observing the following rules:

- all stars must be painted in a single move (i.e. it is forbidden to take the pen away from the paper);
- it is forbidden to paint the same segment of non-zero length more than once;
- the stars can intersect only in their vertexes;
- the length of a side of the regular pentagon, in which Rubik paints each star, must equal 10.

Help Rubik to cope with this hard task.

Input

A single line contains an integer (1 ≤ *n* ≤ 100) — the number of stars to paint.

Output

On the first line print an integer *m* (1 ≤ *m* ≤ 5·*n*). On the next *m* lines print coordinates of *m* distinct points with accuracy of at least 9 and at most 100 digits after decimal point. All coordinates should not exceed 5000 in their absolute value. On each of the next *n* lines print 5 integers — the indexes of the points that form the given star in the clockwise or counterclockwise order. On the next line print 5·*n* + 1 integers — the numbers of points in the order, in which Rubik paints stars. That is, if number with index *i* is *a*_{i}, and number with index *i* + 1 is *a*_{i + 1}, then points with indexes *a*_{i} and *a*_{i + 1} will have a segment painted between them.

You can consider all *m* printed points indexed from 1 to *m* in the order, in which they occur in the output. Separate the numbers on the lines with whitespaces.

Note that the answer has an imprecise validation. Try to obtain as accurate a solution as possible. The validator performs all calculations considering that the absolute error of a participant's answer is not more than 10^{ - 8}.

Examples

Input

1

Output

5

3.830127018922193 3.366025403784439

-3.601321235851749 10.057331467373021

0.466045194906253 19.192786043799030

10.411264148588986 18.147501411122495

12.490381056766580 8.366025403784439

1 2 3 4 5

1 3 5 2 4 1

Note

The initial position of points in the sample is:

The order in which Rubik can paint segments is:

Codeforces (c) Copyright 2010-2020 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Jun/05/2020 20:00:11 (g1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|