CSES - Square Subsets
  • Time limit: 1.00 s
  • Memory limit: 512 MB

Given an array of nn integers, count the number of subsets whose elements' product is a square number.

Also count the empty subset with product equal to one.

Input

The first line has an integer nn: the size of the array.

The next line has nn integers x1,x2,,xnx_1, x_2,\dots, x_n: the contents of the array.

Output

Print one integer: the answer to the problem modulo 109+710^9 + 7.

Constraints

  • 1n50001 \le n \le 5000
  • 1xi50001 \le x_i \le 5000

Example

Input:

4
2 2 3 6

Output:

4