#1961. [noi省选联考 2021 A/B 卷] 滚榜

[noi省选联考 2021 A/B 卷] 滚榜

题目描述

封榜是 ICPC 系列竞赛中的一个特色机制。ICPC 竞赛是实时反馈提交结果的程序设计竞赛,参赛选手与场外观众可以通

过排行榜实时查看每个参赛队伍的过题数与排名。竞赛的最后一小时会进行“封榜”,即排行榜上将隐藏最后一小时内的提交的结果。赛后通过滚榜环节将最后一小时的结果(即每只队伍最后一小时的过题数)公布。

Alice 围观了一场 ICPC 竞赛的滚榜环节。本次竞赛共有 nn 支队伍参赛,队伍从 1n1 \sim n 编号,ii 号队伍在封榜前通过的题数为 aia_i。排行榜上队伍按照过题数从大到小进行排名,若两支队伍过题数相同,则编号小的队伍排名靠前。

滚榜时主办方以 bib_i 不降的顺序依次公布了每支队伍在封榜后的过题数 bib_i(最终该队伍总过题数为 ai+bia_i + b_i),并且每公布一支队伍的结果,排行榜上就会实时更新排名。Alice 并不记得队伍被公布的顺序,也不记得最终排行榜上的排名情况,只记得每次公布后,本次被公布结果的队伍都成为了新排行榜上的第一名,以及所有队伍在封榜后一共通过了 mm 道题(即 i=1nbi=m\sum_{i = 1}^{n} b_i = m)。

现在 Alice 想请你帮她算算,最终排行榜上队伍的排名情况可能有多少种。

</p>

输入输出格式

输入格式


第一行,包含两个正整数 $n, m$,表示队伍数量与它们封榜后的总过题数。 第二行,包含 $n$ 个正整数,表示 $a_i$。

输出格式


仅一行,一个整数,表示答案。

输入输出样例

输入样例 #1

3 6
1 2 1

输出样例 #1

5

输入样例 #2

6 50
4 7 9 3 0 3

输出样例 #2

96

输入样例 #3

11 300
6 8 8 12 0 11 6 1 0 15 5

输出样例 #3

30140983

说明

【样例 #1 解释】

  1. 最终排名:1,3,21, 3, 2,滚榜情况(按公布顺序,下同):b2=0b_2 = 0b3=2b_3 = 2b1=4b_1 = 4

  2. 最终排名:2,1,32, 1, 3,滚榜情况:b3=2b_3 = 2b1=2b_1 = 2b2=2b_2 = 2

  3. 最终排名:2,3,12, 3, 1,滚榜情况:b1=1b_1 = 1b3=2b_3 = 2b2=3b_2 = 3

  4. 最终排名:3,1,23, 1, 2,滚榜情况:b2=0b_2 = 0b1=2b_1 = 2b3=4b_3 = 4

  5. 最终排名:3,2,13, 2, 1,滚榜情况:b1=1b_1 = 1b2=1b_2 = 1b3=4b_3 = 4


【数据范围】

对于所有测试数据:1n131 \le n \le 131m5001 \le m \le 5000ai1040 \le a_i \le {10}^4

每个测试点的具体限制见下表:

测试点编号 nn \le mm \le
121 \sim 2 22 1010
353 \sim 5 33
686 \sim 8 88 100100
9129 \sim 12 1010 200200
131613 \sim 16 1212 300300
172017 \sim 20 1313 500500