#D29. Multiples of Length
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>