#D2936. Lost Array

    ID: 2443 Type: Default 1000ms 256MiB

Lost Array

Lost Array

Bajtek, known for his unusual gifts, recently got an integer array x_0, x_1, …, x_{k-1}.

Unfortunately, after a huge array-party with his extraordinary friends, he realized that he'd lost it. After hours spent on searching for a new toy, Bajtek found on the arrays producer's website another array a of length n + 1. As a formal description of a says, a_0 = 0 and for all other i (1 ≤ i ≤ n) a_i = x_{(i-1)mod k} + a_{i-1}, where p mod q denotes the remainder of division p by q.

For example, if the x = [1, 2, 3] and n = 5, then:

  • a_0 = 0,
  • a_1 = x_{0mod 3}+a_0=x_0+0=1,
  • a_2 = x_{1mod 3}+a_1=x_1+1=3,
  • a_3 = x_{2mod 3}+a_2=x_2+3=6,
  • a_4 = x_{3mod 3}+a_3=x_0+6=7,
  • a_5 = x_{4mod 3}+a_4=x_1+7=9.

So, if the x = [1, 2, 3] and n = 5, then a = [0, 1, 3, 6, 7, 9].

Now the boy hopes that he will be able to restore x from a! Knowing that 1 ≤ k ≤ n, help him and find all possible values of k — possible lengths of the lost array.

Input

The first line contains exactly one integer n (1 ≤ n ≤ 1000) — the length of the array a, excluding the element a_0.

The second line contains n integers a_1, a_2, …, a_n (1 ≤ a_i ≤ 10^6).

Note that a_0 is always 0 and is not given in the input.

Output

The first line of the output should contain one integer l denoting the number of correct lengths of the lost array.

The second line of the output should contain l integers — possible lengths of the lost array in increasing order.

Examples

Input

5 1 2 3 4 5

Output

5 1 2 3 4 5

Input

5 1 3 5 6 8

Output

2 3 5

Input

3 1 5 3

Output

1 3

Note

In the first example, any k is suitable, since a is an arithmetic progression.

Possible arrays x:

  • [1]
  • [1, 1]
  • [1, 1, 1]
  • [1, 1, 1, 1]
  • [1, 1, 1, 1, 1]

In the second example, Bajtek's array can have three or five elements.

Possible arrays x:

  • [1, 2, 2]
  • [1, 2, 2, 1, 2]

For example, k = 4 is bad, since it leads to 6 + x_0 = 8 and 0 + x_0 = 1, which is an obvious contradiction.

In the third example, only k = n is good.

Array [1, 4, -2] satisfies the requirements.

Note that x_i may be negative.

inputFormat

Input

The first line contains exactly one integer n (1 ≤ n ≤ 1000) — the length of the array a, excluding the element a_0.

The second line contains n integers a_1, a_2, …, a_n (1 ≤ a_i ≤ 10^6).

Note that a_0 is always 0 and is not given in the input.

outputFormat

Output

The first line of the output should contain one integer l denoting the number of correct lengths of the lost array.

The second line of the output should contain l integers — possible lengths of the lost array in increasing order.

Examples

Input

5 1 2 3 4 5

Output

5 1 2 3 4 5

Input

5 1 3 5 6 8

Output

2 3 5

Input

3 1 5 3

Output

1 3

Note

In the first example, any k is suitable, since a is an arithmetic progression.

Possible arrays x:

  • [1]
  • [1, 1]
  • [1, 1, 1]
  • [1, 1, 1, 1]
  • [1, 1, 1, 1, 1]

In the second example, Bajtek's array can have three or five elements.

Possible arrays x:

  • [1, 2, 2]
  • [1, 2, 2, 1, 2]

For example, k = 4 is bad, since it leads to 6 + x_0 = 8 and 0 + x_0 = 1, which is an obvious contradiction.

In the third example, only k = n is good.

Array [1, 4, -2] satisfies the requirements.

Note that x_i may be negative.

样例

5
1 2 3 4 5
5

1 2 3 4 5

</p>