问题 1849 --On the Bench

1849: On the Bench

时间限制: 2 Sec  内存限制: 256 MB
提交: 0  解决: 0
[提交][状态][讨论版][命题人:]

题目描述

time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

A year ago on the bench in public park Leha found an array of n numbers. Leha believes that permutation p is right if for all 1≤i<n condition, that api·api+1 is not perfect square, holds. Leha wants to find number of right permutations modulo 109+7.

Input

First line of input data contains single integer n (1≤n≤300) − length of the array.

Next line contains n integers a1,a2,... ,an (1≤ai≤109) − found array.

Output

Output single integer − number of right permutations modulo 109+7.

Examples
Input
3
1 2 4
Output
2
Input
7
5 2 4 2 4 1 1
Output
144
Note

For first example:

[1,2,4] − right permutation, because 2 and 8 are not perfect squares.

[1,4,2] − wrong permutation, because 4 is square of 2.

[2,1,4] − wrong permutation, because 4 is square of 2.

[2,4,1] − wrong permutation, because 4 is square of 2.

[4,1,2] − wrong permutation, because 4 is square of 2.

[4,2,1] − right permutation, because 8 and 2 are not perfect squares.

输入

输出

提示

来源

 

[提交][状态]