CF2131G Wafu!

题目描述

为了帮助 Kudryavka 提高数学能力,她得到了一个包含 $n$ 个互不相同正整数的集合 $S$。 初始时,她的得分为 $1$。只要集合不为空,她可以对集合执行任意次数如下操作: 1. 设 $S$ 的最小值为 $m$。 2. 将她的得分乘以 $m$。 3. 从 $S$ 中移除 $m$。 4. 对于每个满足 $1 \le i < m$ 的整数 $i$,将 $i$ 加入集合 $S$。可以证明在此步骤中不会添加重复元素。 她沉迷于执行这些操作,但在进行了 $k$ 次操作后,她忘记了自己的得分。请你帮她计算她的得分,结果对 $10^9+7$ 取模。

输入格式

每组测试数据包含多组测试用例。第一行包含一个整数 $t$($1 \le t \le 10^4$),表示测试用例的数量。 每个测试用例的第一行包含两个整数 $n$ 和 $k$($1 \le n \le 2 \times 10^5$,$1 \le k \le 10^9$)。 第二行包含 $n$ 个整数 $s_1, s_2, \dots, s_n$($1 \le s_i \le 10^9$,$s_i \neq s_j$),表示初始集合 $S$ 的元素。保证在每次操作前集合 $S$ 都不为空。 保证所有测试用例中 $n$ 的总和不超过 $2 \times 10^5$。

输出格式

对于每个测试用例,输出一个整数,表示答案对 $10^9+7$ 取模后的结果。

说明/提示

让我们模拟第一个测试用例的过程: $$ \{1,3\} \xrightarrow{\text{移除 } 1} \{3\} \xrightarrow[\text{添加 } 1,2]{\text{移除 } 3} \{1,2\} \xrightarrow{\text{移除 } 1} \{2\} $$ 被移除的值依次为 $1$、$3$ 和 $1$,因此她的得分为 $1 \times 3 \times 1 = 3$。 在第二个测试用例中,答案为 $1 \times 4 \times 1 \times 2 \times 1 \times 3 = 24$。 由 ChatGPT 4.1 翻译