CF1777B.Emordnilap

传统题 时间 2000 ms 内存 256 MiB 4 尝试 1 已通过 1 标签

Emordnilap

题目描述

一个长度为 nn 的排列是一个由 11nnnn 个互不相同的整数按任意顺序组成的数组。例如,[2,3,1,5,4][2,3,1,5,4] 是一个排列,但 [1,2,2][1,2,2] 不是排列(22 在数组中出现了两次),[1,3,4][1,3,4] 也不是排列(n=3n=3 但数组中有 44)。长度为 nn 的排列共有 $n! = n \cdot (n-1) \cdot (n - 2) \cdot \ldots \cdot 1$ 种。

给定一个 nn 个数的排列 pp,我们构造一个长度为 2n2n 的数组 aa,其内容为 pppp 的逆序拼接而成。我们定义排列 pp 的美丽值为数组 aa 中的逆序对数量。

数组 aa 中的逆序对数量是指满足 i<ji < jai>aja_i > a_j 的下标对 (i,j)(i, j) 的数量。

例如,对于排列 p=[1,2]p = [1, 2]a=[1,2,2,1]a = [1, 2, 2, 1]aa 中的逆序对为 (2,4)(2, 4)(3,4)(3, 4)(假设下标从 11 开始)。因此,pp 的美丽值为 22

你的任务是求出所有长度为 nn 的排列的美丽值之和。请输出该值对 10000000071\,000\,000\,007109+710^9 + 7)取模后的结果。

输入格式

每组测试数据包含多组测试用例。第一行包含一个整数 tt1t1051 \le t \le 10^5),表示测试用例的数量。

接下来每组测试用例仅一行,包含一个整数 nn1n1051 \leq n \leq 10^5)。

保证所有测试用例中 nn 的总和不超过 10510^5

输出格式

对于每组测试用例,输出一个整数,表示所有长度为 nn 的排列的美丽值之和对 10000000071\,000\,000\,007109+710^9 + 7)取模后的结果。

说明/提示

对于样例的第一个测试用例,p=[1]p = [1] 是唯一的排列。a=[1,1]a = [1, 1] 没有逆序对。

对于样例的第二个测试用例,排列为 [1,2][1, 2][2,1][2, 1]。它们对应的 aa 分别为 [1,2,2,1][1, 2, 2, 1][2,1,1,2][2, 1, 1, 2],两者的逆序对数量均为 22

由 ChatGPT 4.1 翻译

样例

3
1
2
100
0
4
389456655

在线编程 IDE

建议全屏模式获得最佳体验