#L4326. 「ROIR 2024 Day2」三元组划分

「ROIR 2024 Day2」三元组划分


题目描述

译自 ROI Regional 2024 Day2 T3. Разбиение на тройки

在玛莎的生日那天,她像往常一样收到一个包含 nn 个自然数的数组 aa,其中每个数字都在 11mm 之间。玛莎非常喜欢数字 33,因此数组的长度是 33 的倍数。

玛莎决定将数字组合成三元组:每个三元组要么由三个相同的数字组成,要么由三个连续的数字组成。换句话说,每个三元组的形式要么是 (x,x,x)(x, x, x),要么是 (x,x+1,x+2)(x, x+1, x+2),其中 xx 是某个自然数。

玛莎想要玩这个礼物数组,她想知道有多少种方法可以将数组中的数字划分为这样的三元组。如果两个划分方式不能通过一一对应的方式使得每个三元组中的数字相同,则认为这两种划分方式不同。由于划分的数量可能非常大,玛莎只需要知道其对 109+710^9+7 取模的结果。

请帮助玛莎计算将数组划分为三元组的方法数,并对 109+710^9+7 取模。


输入格式

第一行输入包含两个整数 nnmm1n50001 \le n \le 50001m50001 \le m \le 5000n=3kn=3\cdot k 对于某个自然数 kk)。

第二行包含 nn 个整数 aia_i1aim1 \le a_i \le m),表示数组中的数字。


输出格式

输出一个整数,表示将数组划分为三元组的方法数,并对 109+710^9+7 取模。


样例 1

输入

9 4
3 4 2 4 4 2 3 3 2

输出

2

在第一个样例中,有两种方法可以将数字划分为三元组: {(2,2,2),(3,3,3),(4,4,4)}\{(2, 2, 2), (3, 3, 3), (4, 4, 4)\}{(2,3,4),(2,3,4),(2,3,4)}\{(2, 3, 4), (2, 3, 4), (2, 3, 4)\}


样例 2

输入

6 3
1 2 3 1 2 1

输出

0

数据范围与提示

详细子任务附加限制及分值如下表所示。

子任务 分值 附加限制 子任务依赖
1 10 m3m \le 3
2 8 m4m \le 4 1
3 10 每个数字从 11mm 最多出现两次
4 12 数组 aa 不包含能被 44 整除的数字 1
5 29 n500n \le 500m500m \le 500
6 31 无附加限制 1, 2, 3, 4, 5