#1331. [CZOJ 一周一测 R20 F] 骰子

[CZOJ 一周一测 R20 F] 骰子

题目描述

小 C 喜欢骰子,尽管这些骰子非常奇怪。

小 C 的手中有 nn 个不同的骰子,其中第 ii 个骰子是 aia_i 面骰子,每个面上的数字依次为 1,2,3,,ai1,2,3,\cdots,a_i

现在,小 C 要选择其中的 kk 个骰子,并对于这 kk 个骰子中的每一个骰子,选择一个面朝上。

小 C 想要知道,共有多少种不同的选择骰子和选择朝上的面的方案,可以使所有选择的骰子的朝上的面上的数字之和不大于 pp

两种选择骰子和选择朝上的面的方案不同,当且仅当存在一个只在其中一种选择方案中出现的骰子存在一个同时出现在这两种选择方案的骰子的朝上的面上的数字不同

由于答案可能很大,所以你只需要输出答案对 998244353998244353 取模的结果。

输入格式

第一行三个整数 n,k,pn,k,p

第二行 nn 个整数,表示数组 aa

输出格式

一行一个整数,表示满足条件的不同的选择骰子和选择朝上的面的方案数对 998244353998244353 取模的结果。

样例 #1

样例输入 #1

3 2 5
3 4 6

样例输出 #1

28

样例 #2

样例输入 #2

4 4 13
6 4 5 3

样例输出 #2

296

提示

【样例 #3】

见附加文件中的 dice/dice3.indice/dice3.ans

该样例满足测试点 88 的限制。

【样例 #4】

见附加文件中的 dice/dice4.indice/dice4.ans

该样例满足测试点 1111 的限制。

【样例 #5】

见附加文件中的 dice/dice5.indice/dice5.ans

该样例满足测试点 1313 的限制。

【样例 #6】

见附加文件中的 dice/dice6.indice/dice6.ans

该样例满足测试点 2020 的限制。

【数据范围】

对于 100%100\% 的数据,1kn2001 \le k \le n \le 2001p10001 \le p \le 10001ai1091 \le a_i \le 10^9

测试点编号 nn \le pp \le aia_i \le 特殊性质
11 88 88 88
232\sim3 10001000
454\sim5 1212 10910^9
676\sim7 5050 8080 8080
8108\sim10 10910^9
111211\sim12 200200 10001000 11
131513\sim15 400400 10910^9
162016\sim20 10001000

特殊性质:保证 k=nk=n