AT_abc324_d [ABC324D] Square Permutation
题目描述
给定一个仅由数字组成、长度为 $N$ 的字符串 $S$。
请计算,将 $S$ 的各位数字重新排列后,能组成多少个十进制整数,使得这些整数是完全平方数。
更严格地说,定义 $S$ 的第 $i$ 位数字为 $s_i$($1\leq i\leq N$)。
对于 $(1,\ldots,N)$ 的任意一个排列 $P=(p_1,p_2,\ldots,p_N)$,可以表示出一个整数 $\displaystyle\sum_{i=1}^N s_{p_i}10^{N-i}$。请计算,在所有可能的排列中,有多少个不同的整数是完全平方数。
输入格式
输入从标准输入中给出,格式如下:
> $N$ $S$
输出格式
请输出一个整数,表示满足条件的不同完全平方数的个数。
说明/提示
#### 限制条件
- $1\leq N\leq 13$
- $S$ 是长度为 $N$ 的仅由数字组成的字符串
- $N$ 是整数
#### 样例解释 1
当 $P=(4,2,3,1)$ 时,有 $s_4\times10^3+s_2\times10^2+s_3\times10^1+s_1=324=18^2$。
当 $P=(3,2,4,1)$ 时,有 $s_3\times10^3+s_2\times10^2+s_4\times10^1+s_1=2304=48^2$。
除此之外,没有其他排列能得到完全平方数,因此输出 $2$。
#### 样例解释 2
当 $P=(1,3,2)$ 或 $P=(3,1,2)$ 时,有 $\displaystyle\sum_{i=1}^N s_{p_i}10^{N-i}=1=1^2$。
当 $P=(2,1,3)$ 或 $P=(2,3,1)$ 时,有 $\displaystyle\sum_{i=1}^N s_{p_i}10^{N-i}=100=10^2$。
除此之外,没有其他排列能得到完全平方数,因此输出 $2$。
请注意,如果不同的排列得到相同的数,只计为 $1$ 个。
由 ChatGPT 4.1 翻译