#L3712. 「AHOI2022」排列

    ID: 3119 传统题 1500ms 256MiB 尝试: 2 已通过: 1 难度: 8 上传者: 标签>数论积性函数欧几里得算法解线性同余方程组合数学容斥原理数据结构搜索DFS

「AHOI2022」排列

「AHOI2022」排列

题目描述

对于一个长度为 nn 的排列 P=(p1,p2,,pn)P = (p_1, p_2, \ldots, p_n) 和整数 k0k \ge 0,定义 PPkk 次幂

$$P^{(k)} = \left( p^{(k)}_1, p^{(k)}_2, \ldots, p^{(k)}_n \right), $$

该排列的第 ii 项为

$$p^{(k)}_i = \begin{cases} i, & k = 0, \\ p^{(k - 1)}_{p_i}, & k > 0. \end{cases} $$

容易证明任意排列的任意次幂都是一个排列。

定义排列 PP 的循环值 v(P)v(P) 为最小的正整数 kk 使得 P(k+1)=PP^{(k + 1)} = P

给出一个长度为 nn 的排列 A=(a1,a2,,an)A = (a_1, a_2, \ldots, a_n),对于整数 1i,jn1 \le i, j \le n,定义 f(i,j)f(i, j):若存在 k0k \ge 0 使得 ai(k)=ja^{(k)}_i = j,则 f(i,j)=0f(i, j) = 0,否则设排列 AijA_{i j} 为将排列 AA 的第 iiaia_i 和第 jjaja_j 交换后得到的排列,则 f(i,j)=v(Aij)f(i, j) = v(A_{i j})

i=1nj=1nf(i,j)\sum_{i = 1}^{n} \sum_{j = 1}^{n} f(i, j)

的值。答案可能很大,你只需要输出其对 109+710^9 + 7 取模的结果。

输入格式

本题有多组测试数据。输入数据的第一行为一个整数 TT,表示测试数据组数。

对于每组测试数据,第一行一个正整数 nn 表示排列的长度,接下来一行 nn 个整数 a1,a2,,ana_1, a_2, \ldots, a_n,描述输入的排列。

输出格式

对于每组数据输出一行一个整数,表示题目所求的答案对 109+710^9 + 7 取模的结果。

样例 1

输入

2
3
1 2 3
3
2 3 1

输出

12
0

对于第一组测试数据,$f(1, 2) = f(2, 1) = f(2, 3) = f(3, 2) = f(1, 3) = f(3, 1) = 2$,其余的 f(i,j)f(i, j) 均为 00

对于第二组测试数据,所有的 f(i,j)f(i, j) 均为 00

样例 2

见附加文件下的 perm2.inperm2.ans

该组样例中,第一个测试数据满足 n35n \le 35,前四个测试数据满足 n200n \le 200,所有测试数据满足 n2500n \le 2500

样例 3

见附加文件下的 perm3.inperm3.ans

该组样例中,第一个测试数据满足特殊性质 A,第二个测试数据满足特殊性质 B,第三个测试数据满足特殊性质 C,前四个测试数据满足 n105n \le 10^5,第五个测试数据满足 n5×105n \le 5 \times 10^5

数据范围与提示

对于 100%100\% 的测试数据,1T51 \le T \le 51n5×1051 \le n \le 5 \times 10^51ain1 \le a_i \le n

测试点编号 nn \le 特殊性质
1 ~ 2 10510^5 A
3 35
4 200
5 2500
6 10510^5 B
7 C
8
9 ~ 10 5×1055 \times 10^5

特殊性质 Aai=(imodn)+1a_i = (i \bmod n) + 1

特殊性质 B:对于任意 1in1 \le i \le n,存在 1k201 \le k \le 20ai(k)=ia^{(k)}_i = i

特殊性质 C:存在大小不超过 1010 的集合 SS,使得对于任意 1in1 \le i \le n,存在 xS,k0x \in S, k \ge 0ax(k)=ia^{(k)}_x = i

输入数据规模较大,请使用较为快速的输入方式。