#D29. Multiples of Length

    ID: 23 Type: Default 1000ms 256MiB

Multiples of Length

Multiples of Length

You are given an array a of n integers.

You want to make all elements of a equal to zero by doing the following operation exactly three times:

  • Select a segment, for each number in this segment we can add a multiple of len to it, where len is the length of this segment (added integers can be different).

It can be proven that it is always possible to make all elements of a equal to zero.

Input

The first line contains one integer n (1 ≤ n ≤ 100 000): the number of elements of the array.

The second line contains n elements of an array a separated by spaces: a_1, a_2, ..., a_n (-10^9 ≤ a_i ≤ 10^9).

Output

The output should contain six lines representing three operations.

For each operation, print two lines:

  • The first line contains two integers l, r (1 ≤ l ≤ r ≤ n): the bounds of the selected segment.

  • The second line contains r-l+1 integers b_l, b_{l+1}, ..., b_r (-10^{18} ≤ b_i ≤ 10^{18}): the numbers to add to a_l, a_{l+1}, …, a_r, respectively; b_i should be divisible by r - l + 1.

Example

Input

4 1 3 2 4

Output

1 1 -1 3 4 4 2 2 4 -3 -6 -6

inputFormat

Input

The first line contains one integer n (1 ≤ n ≤ 100 000): the number of elements of the array.

The second line contains n elements of an array a separated by spaces: a_1, a_2, ..., a_n (-10^9 ≤ a_i ≤ 10^9).

outputFormat

Output

The output should contain six lines representing three operations.

For each operation, print two lines:

  • The first line contains two integers l, r (1 ≤ l ≤ r ≤ n): the bounds of the selected segment.

  • The second line contains r-l+1 integers b_l, b_{l+1}, ..., b_r (-10^{18} ≤ b_i ≤ 10^{18}): the numbers to add to a_l, a_{l+1}, …, a_r, respectively; b_i should be divisible by r - l + 1.

Example

Input

4 1 3 2 4

Output

1 1 -1 3 4 4 2 2 4 -3 -6 -6

样例

4
1 3 2 4
1 1

-1 2 4 9 6 12 1 4 0 -12 -8 -16

</p>